new Date处理日期格式及兼容浏览器问题
生活随笔
收集整理的這篇文章主要介紹了
new Date处理日期格式及兼容浏览器问题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
new Date處理日期格式及兼容瀏覽器問題
在前端處理日期格式問題,需要寫日期格式的函數
?//日期格式化???Date.prototype.format?=?function(fmt)?{??????var?o?=?{?????????"M+"?:?this.getMonth()+1,?????????????????//月份?????????"d+"?:?this.getDate(),????????????????????//日?????????"h+"?:?this.getHours(),???????????????????//小時?????????"m+"?:?this.getMinutes(),?????????????????//分?????????"s+"?:?this.getSeconds(),?????????????????//秒?????????"q+"?:?Math.floor((this.getMonth()+3)/3),?//季度?????????"S"??:?this.getMilliseconds()?????????????//毫秒?????};?????if(/(y+)/.test(fmt))?{????????????fmt=fmt.replace(RegExp.$1,?(this.getFullYear()+"").substr(4?-?RegExp.$1.length));?????}?????for(var?k?in?o)?{????????if(new?RegExp("("+?k?+")").test(fmt)){?????????????fmt?=?fmt.replace(RegExp.$1,?(RegExp.$1.length==1)???(o[k])?:?(("00"+?o[k]).substr((""+?o[k]).length)));?????????}?????}????return?fmt;?}
然后在格式化后臺傳過來的時間 new?Date(Date.parse(assessVo.createdate.replace(/-/g,"/"))).format("yyyy.MM.dd")
assessVo.createdate是后臺傳過來date類型的json字符串 但是這里用到了Date.parse的方法,是因為new Date(assessVo.createdate).format("yyyy.MM.dd") 在chrom瀏覽器可以正常顯示但是在其他瀏覽器就成成了invlidate或是NaN的顯示,在參考了網上解決的例子:
然后在格式化后臺傳過來的時間 new?Date(Date.parse(assessVo.createdate.replace(/-/g,"/"))).format("yyyy.MM.dd")
assessVo.createdate是后臺傳過來date類型的json字符串 但是這里用到了Date.parse的方法,是因為new Date(assessVo.createdate).format("yyyy.MM.dd") 在chrom瀏覽器可以正常顯示但是在其他瀏覽器就成成了invlidate或是NaN的顯示,在參考了網上解決的例子:
new Date在不同瀏覽器識別問題
引言: 同一種語言javascript,在不同的瀏覽器中,存在語言兼容性問題,本質上是由于不同的瀏覽器是支持的語言標準和實現上各有差異。本文將基于new Date來創建Date對象來分析這個問題。
1. 問題的提出, 開始時間和結束時間空間無法正確的傳遞值
在頁面中,我們使用了一個時間上的組件來開發時間選擇框,但是發現在Firefox下是無法正常工作的,在Chrome下是可以正常運行的。 問題出在哪里呢?
2. 問題分析
結果分析發現是由于如下代碼產生的問題:
| 123456 | var timestart = '2010-05-04';var timeend = '2015-04-01';var time1 = (timestart+' 00:00:00').toString();var time2 = (timeend+' 23:59:59').toString();timestart = new?Date(time1);timeend = new?Date(time2); |
?
問題就在于 new Date(time1)這個構造函數無法正確的生成Date對象,其值為NaN. 怪哉,問題在哪里呢?
3. 各個瀏覽器上的表現
在IE下的執行情況:
在Firefox下的執行情況:
在Chrome下的執行情況:
通過以上的分析,可以得知,這個javascript的腳本在Chrome下是可以正確執行的,但是在其他瀏覽器下報出錯誤。
4. 正確的做法
以下列出正確的做法:
| 1234 | var time1 = (timestart+' 00:00:00').toString();var time2 = (timeend+' 23:59:59').toString();timestart = new?Date(Date.parse(str.replace(/-/g,"/"))).getTime();timeend = new?Date(Date.parse(str.replace(/-/g,"/"))).getTime(); |
主要的變化是對默認的日期格式進行了轉換, 基于'/'格式的日期字符串,才是被各個瀏覽器所廣泛支持的,‘-’連接的日期字符串,則是只在chrome下可以正常工作。
?
5. 知識點總結
'2015-05-04'是無法被各個瀏覽器中,使用new Date(str)來正確生成日期對象的。 正確的用法是'2015/05/05'.
總結
以上是生活随笔為你收集整理的new Date处理日期格式及兼容浏览器问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 家政APP开发解决方案
- 下一篇: Stetho增加SD卡路径的数据库