js字符串日期yyyy-MM-dd转化为date示例代码

最近遇到一个问题,就是获取表单中的日期往后台通过json方式传的时候,遇到Date.parse(str)函数在ff下报错: NAN 

找了些资料,发现是由于Date.parse()函数对日期格式有要求:详细参考 Date.parse函数 

对于js操作日期: 

创建一个日期对象: 

var objDate=new Date([arguments list]); 

参数形式有以下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); 

说明: 

month:用英文表示月份名称,从January到December 
mth:用整数表示月份,从0(1月)到11(12月) 
Content 

dd:表示一个月中的第几天,从1到31 
yyyy:四位数表示的年份 
hh:小时数,从0(午夜)到23(晚11点) 
mm:分钟数,从0到59的整数 
ss:秒数,从0到59的整数 
ms:毫秒数,为大于等于0的整数,表示的是需要创建的时间和GMT时间1970年1月1日之间相差的毫秒数。 

我发现了: 

Javascript中日期的构造还可以支持 new Date("yyyy/MM/dd"); 其中:MM是整数表示月份从0(1月)到11(12月),这样再利用正则表达式就很方便地能够转换字符串日期了。 

测试代码: 
复制代码代码如下:

<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> 

输出结果: 

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.οnlοad=function(){ 
var dependedVal="2005-3-4"; 
//根据日期字符串转换成日期 
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(); 
//注意括号,优先级问题,无奈 
alert("相隔年数:"+(now.getFullYear() - dependedDate.getFullYear())); 


其实日期在浏览器和服务器之间传输都要通过毫秒值来传,否则就会报错 400错误!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaScript中可以使用Date对象将字符串日期转化日期对象。下面是一个示例代码: ```javascript let dateString = '2021-06-30'; // 字符串日期 // 将字符串日期转化日期对象 let dateArray = dateString.split('-'); let year = parseInt(dateArray[0]); let month = parseInt(dateArray[1]) - 1; // 月份从0开始计数,需要减去1 let day = parseInt(dateArray[2]); let date = new Date(year, month, day); console.log(date); // 输出:Wed Jun 30 2021 00:00:00 GMT+0800 (中国标准时间) ``` 代码解释: 1. 首先,我们将字符串日期按照 "-" 分割成一个数组。比如,'2021-06-30' 会被分割成 ['2021', '06', '30']。 2. 然后,我们将数组中的每个元素转换为整数类型。 3. 接着,我们使用Date对象的构造函数创建一个日期对象。注意,月份需要减去1,因为月份是从0开始计数,而不是从1开始。 4. 最后,我们可以通过console.log函数打印出日期对象。 上述代码字符串日期 '2021-06-30' 转化为了日期对象,输出的结果是 Wed Jun 30 2021 00:00:00 GMT+0800 (中国标准时间)。你可以根据实际需要,自行修改代码中的日期字符串。 ### 回答2: 要将 JavaScript 字符串日期yyyy-mm-dd转化Date 对象,可以按照以下示例代码操作: ```javascript // 定义一个函数将字符串日期转化Date 对象 function convertToDate(dateStr) { // 将日期字符串按照 "-" 分割成数组 var dateArr = dateStr.split("-"); // 将数组中的年、月、日分别提取出来,用于创建 Date 对象 var year = parseInt(dateArr[0]); var month = parseInt(dateArr[1]) - 1; // 月份是从 0 开始的,所以要减 1 var day = parseInt(dateArr[2]); // 创建并返回一个新的 Date 对象 return new Date(year, month, day); } // 测试代码 var dateString = "2022-03-15"; var dateObject = convertToDate(dateString); console.log(dateObject); ``` 在这段代码中,我们定义了一个 `convertToDate` 函数,它接受一个字符串参数 `dateStr`,并返回相应的 Date 对象。在函数内部,我们首先将传入的日期字符串按照 "-" 分割成数组,并提取出年、月、日的数值部分。然后,我们使用这些数值创建一个新的 Date 对象,并将其返回。 在测试代码部分,我们使用日期字符串 "2022-03-15" 调用 `convertToDate` 函数,并将返回的 Date 对象打印到控制台上。 这样,我们就可以将 JavaScript 字符串日期yyyy-mm-dd转化Date 对象。 ### 回答3: 示例代码如下: var dateString = "yyyy-mm-dd"; var year = Number(dateString.substring(0, 4)); var month = Number(dateString.substring(5, 7)) - 1; var day = Number(dateString.substring(8, 10)); var date = new Date(year, month, day); console.log(date); 以上代码中,我们首先定义了一个字符串变量dateString,它表示一个以"yyyy-mm-dd"格式表示的日期。接着,我们使用substring方法从dateString中提取出年、月、日的数字部分,并将它们转化为数值型变量。 然后,我们使用Date对象的构造函数new Date(year, month, day)来创建一个日期对象。需要注意的是,在Javascript中,月份的表示是从0开始的,所以我们在提取月份时需要将其减1。 最后,我们将创建的日期对象输出到控制台上,以便查看转化的结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值