JS中Date的一些常用方法小結

內置對象Date

Date對象在實際開發中,也使用得非常頻繁,它是一個內置對象,用於表示日期和時間。

Date是用來處理日期和時間的對象,但是與Math對象不同的是:Date是一個構造函數,需要實例化之後才能使用。

接下來第一步:創建Date對象

創建Date對象

創建Date對象有兩種方法:

  • 創建時不傳參數:
    在不傳遞參數的情況下,最後創建的結果是返回系統當前的時間對象

    var date = new Date(); console.log(date); // Wed Sep 28 2022 18:06:49 GMT+0800 (中國標準時間) console.log(typeof date); // object

  • 創建時傳遞參數:
    傳遞參數時表示創建指定時間的對象,參數可以是字符串,也可以是數字,還可以是時間戳。我們按照傳遞參數的類型來分別講解。

  • 參數為字符串

    var date = new Date("2022-09-28 18:06:49"); var date = new Date("2022/09/28 18:06:49"); var date = new Date("2022-09-28T18:06:49"); var date = new Date("2022/09/28T18:06:49"); var date = new Date("2022-09-28"); var date = new Date("2022/09/28"); var date = new Date("2022-09-28T00:00:00"); var date = new Date("2022/09/28T00:00:00");

通過上面的代碼,我們可以看到在將時間字符串作為參數傳入的時候,我們要遵循的格式就是:年月日 具體時間,其中年月日之間使用-或者/連接,具體時間使用:連接;年月日和具體時間的連接可以使用空格隔開或者T隔開。

  • 參數為多個數字

    var date = new Date(x,y,z,a,b,c,d);

  • x:表示年份,必須傳遞,否則會報錯
  • y: 表示月份,從0開始,0表示1月,1表示2月,以此類推,如果不傳遞,默認為0
  • z: 表示日期,如果不傳遞,默認為1
  • a: 表示小時,如果不傳遞,默認為0
  • b: 表示分鐘,如果不傳遞,默認為0
  • c: 表示秒,如果不傳遞,默認為0
  • d: 表示毫秒,如果不傳遞,默認為0

多個參數之間我們使用逗號間隔,如果不傳遞的參數,會使用默認值(年份除外,年份必須傳參)。

  • 參數為時間戳

    var date = new Date(時間戳);

日期的格式化

在實際開發中,我們經常需要將日期格式化,比如:將日期格式化為:2022-09-28 18:06:49,這個時候我們就需要使用到Date對象的format方法。

或者我們需要獲取日期的指定部分,這個時候就需要用到Date對象自帶的方法瞭。

Date對象自帶的方法

方法名 含義 備註
getFullYear() 獲取年份  
getMonth() 獲取月:0-11 0代表一月
getDate() 獲取日:1-31  
getDay() 獲取星期:0-6 0代表周日;1代表周一
getHours() 獲取小時:0-23  
getMinutes() 獲取分鐘:0-59  
getSeconds() 獲取秒:0-59  
getMilliseconds() 獲取毫秒 1s = 1000ms

獲取時間戳

什麼是時間戳呢?

時間戳就是從格林威治標準時間的1970年1月1日,0時0分0秒到當前日期所花費的毫秒數(1秒 = 1000毫秒)。

那為什麼需要時間戳呢?

這是因為在計算機中,時間是以數字的形式存儲的,而不是以字符串的形式存儲的,所以我們需要將時間轉換為數字,這個數字就是時間戳。
而時間戳的存在就是為瞭統一時間的單位。

如何獲取時間戳呢?

下面集中常見的方法:

  • +new Date():獲取當前時間的時間戳

    value = +new Date();

  • Date對象的getTime方法

    var date = new Date();

  • Date對象的valueOf方法

    var date = new Date();

這三種方法都可以獲取當前時間的時間戳。使用頻率從上往下一次遞減。

附:獲得Date總的毫秒數(距離1970年1月1號過瞭多少毫秒)

valueOf();

var date = new Date();
console.log(date.valueOf());//1628750819687

getTime();

var date = new Date();
console.log(date.getTime());//1628750819687

簡單寫法

var date1 = +new Date();
console.log(date1);//1628750819687

H5新增的方法

console.log(Date.now());//1628750819687

總結

到此這篇關於JS中Date的一些常用方法的文章就介紹到這瞭,更多相關JS Date常用方法內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: