js字符串日期yyyy-MM-dd轉(zhuǎn)化為date示例代碼
更新時(shí)間:2014年03月06日 11:16:07 作者:
獲取表單中的日期往后臺(tái)通過(guò)json方式傳的時(shí)候,遇到Date.parse(str)函數(shù)在ff下報(bào)錯(cuò),有類似情況的朋友可以參考下本文
最近遇到一個(gè)問(wèn)題,就是獲取表單中的日期往后臺(tái)通過(guò)json方式傳的時(shí)候,遇到Date.parse(str)函數(shù)在ff下報(bào)錯(cuò): NAN
找了些資料,發(fā)現(xiàn)是由于Date.parse()函數(shù)對(duì)日期格式有要求:詳細(xì)參考 Date.parse函數(shù)
對(duì)于js操作日期:
創(chuàng)建一個(gè)日期對(duì)象:
var objDate=new Date([arguments list]);
參數(shù)形式有以下5種:
view plainnew Date("month dd,yyyy hh:mm:ss");
new Date("month dd,yyyy");
new Date(yyyy,mth,dd,hh,mm,ss);
new Date(yyyy,mth,dd);
new Date(ms);
說(shuō)明:
month:用英文表示月份名稱,從January到December
mth:用整數(shù)表示月份,從0(1月)到11(12月)
Content
dd:表示一個(gè)月中的第幾天,從1到31
yyyy:四位數(shù)表示的年份
hh:小時(shí)數(shù),從0(午夜)到23(晚11點(diǎn))
mm:分鐘數(shù),從0到59的整數(shù)
ss:秒數(shù),從0到59的整數(shù)
ms:毫秒數(shù),為大于等于0的整數(shù),表示的是需要?jiǎng)?chuàng)建的時(shí)間和GMT時(shí)間1970年1月1日之間相差的毫秒數(shù)。
我發(fā)現(xiàn)了:
Javascript中日期的構(gòu)造還可以支持 new Date("yyyy/MM/dd"); 其中:MM是整數(shù)表示月份從0(1月)到11(12月),這樣再利用正則表達(dá)式就很方便地能夠轉(zhuǎn)換字符串日期了。
測(cè)試代碼:
<mce:script type="text/javascript"><!--
document.write("<br/>" + new Date("February 3,2009"));
document.write("<br/>" + new Date("February 3,2009 10:52:03"));
document.write("<br/>");
document.write("<br/>" + new Date(2009,1,3));
document.write("<br/>" + new Date(2009,1,3,10,52,03));
document.write("<br/>");
document.write("<br/>" + new Date(Date.parse("February 3,2009")));
document.write("<br/>" + new Date(Date.parse("February 3,2009 10:52:03")));
document.write("<br/>" + new Date(Date.parse(2009,1,3))); //Output: NAN
document.write("<br/>" + new Date(Date.parse(2009,1,3,10,52,03))); //Output: NAN
document.write("<br/>" + new Date(Date.parse("2009/02/03")));
document.write("<br/>");
document.write("<br/>" + new Date("2009/02/03"));
document.write("<br/>" + new Date("2009/02/03 11:12:13"));
document.write("<br/>" + new Date("2009-02-03")); //Output: NAN
// --></mce:script>
輸出結(jié)果:
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 10:52:03 UTC+0800 2009
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 10:52:03 UTC+0800 2009
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 10:52:03 UTC+0800 2009
NaN
NaN
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 11:12:13 UTC+0800 2009
NaN
-------------------
window.onload=function(){
var dependedVal="2005-3-4";
//根據(jù)日期字符串轉(zhuǎn)換成日期
var regEx = new RegExp("\\-","gi");
dependedVal=dependedVal.replace(regEx,"/");
//dependedVal=dependedVal.replace("\\-","/");//這樣不行
alert(dependedVal)
//parse 需要 2005/3/4 這種格式
var milliseconds=Date.parse(dependedVal);
alert(milliseconds)
var dependedDate=new Date();
dependedDate.setTime(milliseconds);
var now = new Date();
//注意括號(hào),優(yōu)先級(jí)問(wèn)題,無(wú)奈
alert("相隔年數(shù):"+(now.getFullYear() - dependedDate.getFullYear()));
}
其實(shí)日期在瀏覽器和服務(wù)器之間傳輸都要通過(guò)毫秒值來(lái)傳,否則就會(huì)報(bào)錯(cuò) 400錯(cuò)誤!
找了些資料,發(fā)現(xiàn)是由于Date.parse()函數(shù)對(duì)日期格式有要求:詳細(xì)參考 Date.parse函數(shù)
對(duì)于js操作日期:
創(chuàng)建一個(gè)日期對(duì)象:
var objDate=new Date([arguments list]);
參數(shù)形式有以下5種:
復(fù)制代碼 代碼如下:
view plainnew Date("month dd,yyyy hh:mm:ss");
new Date("month dd,yyyy");
new Date(yyyy,mth,dd,hh,mm,ss);
new Date(yyyy,mth,dd);
new Date(ms);
說(shuō)明:
month:用英文表示月份名稱,從January到December
mth:用整數(shù)表示月份,從0(1月)到11(12月)
Content
dd:表示一個(gè)月中的第幾天,從1到31
yyyy:四位數(shù)表示的年份
hh:小時(shí)數(shù),從0(午夜)到23(晚11點(diǎn))
mm:分鐘數(shù),從0到59的整數(shù)
ss:秒數(shù),從0到59的整數(shù)
ms:毫秒數(shù),為大于等于0的整數(shù),表示的是需要?jiǎng)?chuàng)建的時(shí)間和GMT時(shí)間1970年1月1日之間相差的毫秒數(shù)。
我發(fā)現(xiàn)了:
Javascript中日期的構(gòu)造還可以支持 new Date("yyyy/MM/dd"); 其中:MM是整數(shù)表示月份從0(1月)到11(12月),這樣再利用正則表達(dá)式就很方便地能夠轉(zhuǎn)換字符串日期了。
測(cè)試代碼:
復(fù)制代碼 代碼如下:
<mce:script type="text/javascript"><!--
document.write("<br/>" + new Date("February 3,2009"));
document.write("<br/>" + new Date("February 3,2009 10:52:03"));
document.write("<br/>");
document.write("<br/>" + new Date(2009,1,3));
document.write("<br/>" + new Date(2009,1,3,10,52,03));
document.write("<br/>");
document.write("<br/>" + new Date(Date.parse("February 3,2009")));
document.write("<br/>" + new Date(Date.parse("February 3,2009 10:52:03")));
document.write("<br/>" + new Date(Date.parse(2009,1,3))); //Output: NAN
document.write("<br/>" + new Date(Date.parse(2009,1,3,10,52,03))); //Output: NAN
document.write("<br/>" + new Date(Date.parse("2009/02/03")));
document.write("<br/>");
document.write("<br/>" + new Date("2009/02/03"));
document.write("<br/>" + new Date("2009/02/03 11:12:13"));
document.write("<br/>" + new Date("2009-02-03")); //Output: NAN
// --></mce:script>
輸出結(jié)果:
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 10:52:03 UTC+0800 2009
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 10:52:03 UTC+0800 2009
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 10:52:03 UTC+0800 2009
NaN
NaN
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 00:00:00 UTC+0800 2009
Tue Feb 3 11:12:13 UTC+0800 2009
NaN
-------------------
復(fù)制代碼 代碼如下:
window.onload=function(){
var dependedVal="2005-3-4";
//根據(jù)日期字符串轉(zhuǎn)換成日期
var regEx = new RegExp("\\-","gi");
dependedVal=dependedVal.replace(regEx,"/");
//dependedVal=dependedVal.replace("\\-","/");//這樣不行
alert(dependedVal)
//parse 需要 2005/3/4 這種格式
var milliseconds=Date.parse(dependedVal);
alert(milliseconds)
var dependedDate=new Date();
dependedDate.setTime(milliseconds);
var now = new Date();
//注意括號(hào),優(yōu)先級(jí)問(wèn)題,無(wú)奈
alert("相隔年數(shù):"+(now.getFullYear() - dependedDate.getFullYear()));
}
其實(shí)日期在瀏覽器和服務(wù)器之間傳輸都要通過(guò)毫秒值來(lái)傳,否則就會(huì)報(bào)錯(cuò) 400錯(cuò)誤!
相關(guān)文章
JS自動(dòng)適應(yīng)的圖片彈窗實(shí)例
這篇文章介紹了JS自動(dòng)適應(yīng)的圖片彈窗實(shí)例代碼,有需要的朋友可以參考一下2013-06-06
JavaScript設(shè)計(jì)模式--簡(jiǎn)單工廠模式實(shí)例分析【XHR工廠案例】
這篇文章主要介紹了JavaScript設(shè)計(jì)模式--簡(jiǎn)單工廠模式,結(jié)合實(shí)例形式分析了JavaScript設(shè)計(jì)模式中簡(jiǎn)單工廠模式原理與XHR工廠應(yīng)用案例,需要的朋友可以參考下2020-05-05
js多個(gè)物體運(yùn)動(dòng)功能實(shí)例分析
這篇文章主要介紹了js多個(gè)物體運(yùn)動(dòng)功能,結(jié)合實(shí)例形式分析了js實(shí)現(xiàn)多物體運(yùn)動(dòng)功能的原理、實(shí)現(xiàn)技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-12-12
借助FileReader實(shí)現(xiàn)將文件編碼為Base64后通過(guò)AJAX上傳
這篇文章主要介紹了借助FileReader實(shí)現(xiàn)將文件編碼為Base64后通過(guò)AJAX上傳的方法,包括后端對(duì)文件數(shù)據(jù)解碼并保存的PHP代碼,需要的朋友可以參考下2015-12-12
JavaScript中偽協(xié)議 javascript:使用探討
javascript:這個(gè)特殊的協(xié)議類型聲明了URL的主體是任意的javascript代碼,它由javascript的解釋器運(yùn)行2014-07-07
JavaScript–Apple設(shè)備檢測(cè)示例代碼
JavaScript–Apple設(shè)備檢測(cè)示例代碼。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11
JavaScript中你不得不知道的Promise高級(jí)用法分享
在JavaScript中,Promise是一種解決異步編程問(wèn)題的重要方式,本文主要來(lái)和大家探討一下23個(gè)Promise的高級(jí)用法,每一個(gè)都在JavaScript的海洋中航行,讓開(kāi)發(fā)者們能夠以更高效、優(yōu)雅的方式處理異步操作,希望對(duì)大就有所幫助2023-12-12
js實(shí)時(shí)監(jiān)聽(tīng)文本框狀態(tài)的方法
js實(shí)時(shí)監(jiān)聽(tīng)文本框狀態(tài)的方法,這里的方法兼容性不是很好,建議參考腳本之家以前的文章。2011-04-04

