javascript時間與時間戳互轉(zhuǎn)多種方式
javascript獲取時間、時間戳等,最核心的就是利用Date
關(guān)鍵詞去獲取。
一、javascript獲取時間戳
時間戳的獲取方式整理了5種方法,后4種是利用new Date()
實例化對象來獲取當前時間,再對當前獲取的時間再進一步處理獲取時間戳。下面獲取的時間戳都是毫秒ms
級別,如果要轉(zhuǎn)換成秒s
級別,可以在獲取的結(jié)果除以1000即可。
方式一: Date.now()
Date.now()獲取當前時間戳:
Date.now() // 1667960502653
方式二: getTime()
getTime()是通過原型方法直接獲取當前時間戳:
new Date().getTime() // 1667961973698 new Date('2022-11-09 23:59:59').getTime() // 1668009599000
方式三: Date.parse()
Date.parse()將字符串或者時間對象直接轉(zhuǎn)化成時間戳:
Date.parse(new Date()) // 1667960585000 Date.parse(new Date('2022-11-09 12:00:00')) // 1667966400000 Date.parse('2022-11-09 23:59:59') // 1667966400000
注意:該方式將毫秒級別的數(shù)值被轉(zhuǎn)化為000,如果是用秒級別的時間戳且不保留小數(shù)的可以使用該方式,如果精確到毫秒級別,不推薦使用。
方式四: valueOf()
valueOf()返回指定對象的原始值獲得準確的時間戳:
(new Date()).valueOf() // 1667962876782 (new Date('2022-11-09 23:59:59')).valueOf() // 1668009599000
方式五: Number()
Number()將時間對象轉(zhuǎn)化成Number類型的時間戳:
Number(new Date()) // 1667962087928 Number(new Date('2022-11-09 23:59:59')) // 1668009599000
二、javascript時間戳轉(zhuǎn)時間
時間戳轉(zhuǎn)時間的應用場景還是比較常見的,一般在后端返回到前端的數(shù)據(jù)中可能是時間戳,在前端就需要轉(zhuǎn)換成具體的時間展示,接下來整理幾種時間戳轉(zhuǎn)時間的方法及注意事項。
可以用new Date(時間戳)
將時間戳轉(zhuǎn)化成中國標準時間,示例:
new Date(1668009599000); Wed Nov 09 2022 23:59:59 GMT+0800 (中國標準時間)
注意:時間戳必須是Number類型,如果是字符串,解析結(jié)果:Invalid Date
如果后端直接返回時間戳給前端,前端如何轉(zhuǎn)換呢?下面介紹2種實現(xiàn)方式:
方式一:生成’2022/11/9 23:59’格式
function getLocalTime(n) { return new Date(parseInt(n)).toLocaleString().replace(/:\d{1,2}$/,' '); } getLocalTime(1668009599000); 2022/11/9 23:59
也可以使用字符串截取的方法,想取幾位就幾位,注意:空格也算:
function getLocalTime(n) { return new Date(parseInt(n)).toLocaleString().substr(0,16) } getLocalTime(1668009599000); 2022/11/9 23:59
使用正則表達式的方式:
function getLocalTime(n) { return new Date(parseInt(n)).toLocaleString().replace(/年|月/g, "-").replace(/日/g, " "); } getLocalTime(1668009599000); 2022/11/9 23:59:59
方式二:生成’yyyy-MM-dd hh:mm:ss’格式
function getDate(n){ n=new Date(n); return n.toLocaleDateString().replace(/\//g, "-") + " " + n.toTimeString().substr(0, 8); } getDate(1668009599000); 2022-11-9 23:59:59
這種方式在瀏覽器上面有兼容性問題,toLocaleDateString()方法是因瀏覽器而異,比如IE為"2016年8月24日 22:26:19"格式 ;搜狗為"Wednesday, August 24, 2016 22:39:42"
可以用以下方式擁有更好的兼容:
function getData(n) { let now = new Date(n), y = now.getFullYear(), m = now.getMonth() + 1, d = now.getDate(); return y + "-" + (m < 10 ? "0" + m : m) + "-" + (d < 10 ? "0" + d : d) + " " + now.toTimeString().substr(0, 8); } getDate(1668009599000); 2022-11-09 23:59:59
到此這篇關(guān)于javascript時間與時間戳互轉(zhuǎn)詳解的文章就介紹到這了,更多相關(guān)js 時間與時間戳互轉(zhuǎn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript (用setTimeout而非setInterval)
javascript (用setTimeout而非setInterval)如果用setInterval 可能出現(xiàn) 下次調(diào)用會在前一次調(diào)用前調(diào)用2011-12-12js調(diào)試工具 Javascript Debug Toolkit 2.0.0版本發(fā)布
Javascript Debug Toolkit是一個可以跨瀏覽器調(diào)試javascript的開源項目,支持在IE,FIREFOX,SAFARI,CHROME等瀏覽器中調(diào)試javascript。2.0.0版本做了較大變動,增加以下功能2008-12-12