您好,登錄后才能下訂單哦!
這篇文章主要介紹了JavaScript日期對象Date怎么創建和使用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇JavaScript日期對象Date怎么創建和使用文章都會有所收獲,下面我們一起來看看吧。
日期和時間是編程過程中不可繞過的必修課,好在JavaScript
為我們準備好了一個內建的對象Date(日期)。通過該對象,我們可以創建、存儲、修改、測量時間、打印等基礎操作,是每個JavaScript
程序員的必修課之一。
和普通的對象一樣,我們可以使用new Date()
來創建一個Date
對象,還可以在創建的時候傳入一些初始化參數。
不帶參數的創建案例:
let now = new Date()console.log(now)
代碼執行結果如下:
這樣就簡單的輸出了代碼執行時的具體時間,這里顯示的就是2022年6月22日 19點25份24秒
。
創建一個帶有毫秒參數的日期對象,其中milliseconds
指的是自1970年1月1日UTC+0之后的毫秒數(1毫秒=1/1000秒)。
//創建一個時間,舉例1970.1.1時間點0毫秒 let jan01_1970 = new Date(0) console.log(jan01_1970) //創建一個時間,比1970年1.1時間點晚3天(3天*24小時*3600秒*1000毫秒) let jan04_1970 = new Date(3 * 24 * 3600 * 1000) console.log(jan04_1970)
代碼執行結果:
milliseconds
就是從1970年1月1日 00:00:00以來,經過的毫秒數,或者稱之為時間戳。
時間戳是一種簡單的日期數字化表示方式,我們通常使用new Date(milliseconds)
創建一個日期。如果我們已經有了一個日期Date
對象,可以使用date.getTime()
獲得日期對應的時間戳。
注意:
中國處于動8區,所以上例中的時間都不是00:00:00,而是08:00:00
時間戳不僅僅是整數,也可以是負數,例如:
//1969-12-31 00:00:00let dec31_1969 = new Date(-24 * 3600 * 1000)console.log(dec31_1969)
代碼執行結果:
如果每次創建時間都是用時間戳,可能并不方便,因為時間戳計算還是有點難度的。
我們還可以使用時間字符串創建一個時間,舉個例子:
let date = new Date('2022-06-22 00:00:00')console.log(date)
代碼執行結果:
year
——必須是四位的數字;
month
——[0,11]
,0
表示一月;
date——當月的某一天,默認為1
;
hours/minutes/sec/ms
——默認為0;
舉個栗子:
let date = new Date(2022,6,22,20,35,33)console.log(date)
代碼執行結果:
我們還可以指定毫秒數:
let date = new Date(2022,6,22,20,35,33,777)console.log(date)
如果我們有一個Date
對象,我們可以通過Date
對象的內置方法,獲取時間的一部分,例如年份、月份、日期等。
例如我們有日期date
:
let date = new Date(2022,5,22,20,35,33)
getFullYear()
獲取年份,date.getFullYear()
返回2022
;
getMonth()
獲取月份,date.getMonth()
返回5
,也就是6
月;
getDate()
獲取當月的日期,date.getDate()
返回22
;
getDay()
獲取當前時間在一周的哪一天,date.getDay()
返回3
;
注意:
以上日期都是已于當地日期的,比如我這里是中國的時區
獲取年份一定要用
getFullYear
,getYear
會返回兩位數的年份
我們也可以獲得0
時區的時間,也就是UTC
時間,分別對應getUTCFullYear()
、getUTCMonth()
,getUTCDay
等。只需要在get
后插入UTC
即可。
舉個例子:
let date = new Date(2022,5,22,20,35,33)console.log(date.getHours(),date.getUTCHours())
代碼執行結果:
夜里也可以看出,中國時區和0
時區相差8
小時。
getTime()
返回日期的時間戳,方法沒有UTC
模式;
getTimezoneOffset()
返回本地時區和0
時區相差的時間,以分鐘為單位,并且沒有UTC
模式;
我們還可以通過Date
對象的方法設置日期中的某一部分:
setFullYear(year, [month], [date])
設置年份(月份、日)
setMonth(month, [date])
設置月份(日)
setDate(date)
設置日期(月份的第幾天)
setHours(hour, [min], [sec], [ms])
設置小時(分、秒、毫秒)
setMinutes(min, [sec], [ms])
設置分鐘(秒、毫秒)
setSeconds(sec, [ms])
設置秒(毫秒)
setMilliseconds(ms)
設置毫秒
setTime(milliseconds)
(使用自 1970-01-01 00:00:00 UTC+0
以來的毫秒數來設置整個日期)
以上函數中只有setTime()
沒有UTC
變體。
JavaScript
的Date
具備自動校準功能,這為我們針對時間的計算提供了極大的方便。
例如:
let date = new Date(2022,5,38)//注意這里的38console.log(date)
代碼的執行結果:
從執行結果我們可以看出"2022年6月38號"并沒有使程序出現錯誤,而是將日期轉成了”2022年7月8號“。
以上案例驗證了,在JavaScript
中,超出范圍的日期會被Date
對象自動分配。這樣我們就可以非常方便的使用Date
對象進行日期的計算。
例如,我們可以在日期上對年、月、日進行加減法運算:
let date = new Date(2022,5,23)//當前時間是2022-6-23date.setDate(date.getDate() + 8)//計算八天后的時間console.log(date)
代碼執行結果:
同樣的,我們也可以使用date.setSeconds()
方法已秒為單位計算日期。
日期Date
轉為數字的結果和使用date.getTime()
的返回值相同,都是毫秒為單位的數值:
let date = new Date()console.log(+date)
代碼執行結果:
既然時間的本質就是數字,我們也可以進行時間差計算,并且以ms
(毫秒)為單位。
例如:
let date1 = new Date(2022,5,23)let date2 = new Date(2022,5,24)console.log(`時間差為${date2-date1}ms`)
代碼執行結果為:
如果我們希望獲得當前時間,更優的做法是使用Date.now()
方法。這個方法會返回當前時間的時間戳,同時不需要創建額外的Date
對象,這對內存開銷、垃圾回收都是有好處的,而且代碼更簡潔。
舉個栗子:
let begin = Date.now()for(let i = 1;i<100000;i++){ let num = i * i * i;}let end = Date.now()console.log(`consume time ${end - begin}ms`)
代碼執行結果:
Date.parse()
方法可以讀取一個日期字符串,并轉為時間戳,但是字符串必須遵守一定的規則:YYYY-MM-DDTHH:mm:ss.sssZ
。
YYYY-MM-DD
對應年-月-日
T
屬于分隔符
HH:mm:ss.sss
對應時:分:秒.毫秒
Z
可以是+-hh:mm
格式的時區。單個字符Z
表示UTC+0
字符串可以使用省略寫法,例如:YYYY-MM-DD
、YYYY-MM
、YYYY
。
舉個小李子:
let ms = Date.parse('2022-06-23T19:38:30.777+08:00')//時間戳let date = new Date(ms)console.log(date)
代碼執行結果:
關于“JavaScript日期對象Date怎么創建和使用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“JavaScript日期對象Date怎么創建和使用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。