javascript中日期函數(shù)new Date()的瀏覽器兼容性問(wèn)題
同一種語(yǔ)言javascript,在不同的瀏覽器中,存在語(yǔ)言兼容性問(wèn)題,本質(zhì)上是由于不同的瀏覽器是支持的語(yǔ)言標(biāo)準(zhǔn)和實(shí)現(xiàn)上各有差異。本文將基于new Date來(lái)創(chuàng)建Date對(duì)象來(lái)分析這個(gè)問(wèn)題。
1. 問(wèn)題的提出, 開(kāi)始時(shí)間和結(jié)束時(shí)間空間無(wú)法正確的傳遞值
在頁(yè)面中,我們使用了一個(gè)時(shí)間上的組件來(lái)開(kāi)發(fā)時(shí)間選擇框,但是發(fā)現(xiàn)在Firefox下是無(wú)法正常工作的,在Chrome下是可以正常運(yùn)行的。 問(wèn)題出在哪里呢?
2. 問(wèn)題分析
結(jié)果分析發(fā)現(xiàn)是由于如下代碼產(chǎn)生的問(wèn)題:
var timestart = '2010-05-04'; var timeend = '2015-09-05'; var time1 = (timestart+' 00:00:00').toString(); var time2 = (timeend+' 23:59:59').toString(); timestart = new Date(time1); timeend = new Date(time2);
問(wèn)題就在于 new Date(time1)這個(gè)構(gòu)造函數(shù)無(wú)法正確的生成Date對(duì)象,其值為NaN. 怪哉,問(wèn)題在哪里呢?
3. 各個(gè)瀏覽器上的表現(xiàn)
在IE下的執(zhí)行情況:
在Firefox下的執(zhí)行情況:
在Chrome下的執(zhí)行情況:
通過(guò)以上的分析,可以得知,這個(gè)javascript的腳本在Chrome下是可以正確執(zhí)行的,但是在其他瀏覽器下報(bào)出錯(cuò)誤。
4. 正確的做法
以下列出正確的做法:
var time1 = (timestart+' 00:00:00').toString(); var time2 = (timeend+' 23:59:59').toString(); timestart = new Date(Date.parse(time1.replace(/-/g,"/"))).getTime(); timeend = new Date(Date.parse(time2.replace(/-/g,"/"))).getTime();
主要的變化是對(duì)默認(rèn)的日期格式進(jìn)行了轉(zhuǎn)換, 基于'/'格式的日期字符串,才是被各個(gè)瀏覽器所廣泛支持的,‘-'連接的日期字符串,則是只在chrome下可以正常工作。
5. 知識(shí)點(diǎn)總結(jié)
'2015-09-05'是無(wú)法被各個(gè)瀏覽器中,使用new Date(str)來(lái)正確生成日期對(duì)象的。 正確的用法是'2015/09/06'.
相關(guān)文章
微信小程序仿知乎實(shí)現(xiàn)評(píng)論留言功能
這篇文章主要為大家詳細(xì)介紹了微信小程序仿知乎實(shí)現(xiàn)評(píng)論留言功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11微信小程序mpvue點(diǎn)擊按鈕獲取button值的方法
這篇文章主要介紹了小程序mpvue點(diǎn)擊按鈕獲取button值的方法,本文通過(guò)兩種方法,給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05javascript間隔刷新的簡(jiǎn)單實(shí)例
這篇文章介紹了javascript間隔刷新的簡(jiǎn)單實(shí)例,有需要的朋友可以參考一下2013-11-11原生JS使用Canvas實(shí)現(xiàn)拖拽式繪圖功能
這篇文章主要介紹了原生js實(shí)現(xiàn)Canvas實(shí)現(xiàn)拖拽式繪圖,支持畫筆、線條、箭頭、三角形和圓形等等圖形繪制功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2019-06-06JS實(shí)現(xiàn)的驗(yàn)證身份證及獲取地區(qū)功能示例
這篇文章主要介紹了JS實(shí)現(xiàn)的驗(yàn)證身份證及獲取地區(qū)功能,結(jié)合實(shí)例形式分析了JS字符串、數(shù)組及正則操作相關(guān)技巧,需要的朋友可以參考下2017-01-01JavaScript數(shù)組常用方法解析及數(shù)組扁平化
這篇文章主要介紹了JavaScript數(shù)組常用方法解析及數(shù)組扁平化,數(shù)組作為在開(kāi)發(fā)中常用的集合,除了for循環(huán)遍歷以外,還有很多內(nèi)置對(duì)象的方法,包括map,以及數(shù)組篩選元素filter等2022-07-07原生js實(shí)現(xiàn)數(shù)字字母混合驗(yàn)證碼的簡(jiǎn)單實(shí)例
這篇文章主要介紹了原生js實(shí)現(xiàn)數(shù)字字母混合驗(yàn)證碼的簡(jiǎn)單實(shí)例,注釋很詳細(xì),感興趣的小伙伴們可以參考一下2015-12-12