JavaScript中使用Date() 在IE中返回NaN或者在Safari中返回Invalid Date

原文参考链接

JavaScript中可以使用Date对象,例如 
var d = new Date();
这步操作仅能得到当前时间,如果需要过去或者将来的时间,需要使用合适的参数。   

问题来了

在IE或者Safari中使用如下两种方式:

var d = new Date("2011-02-07"); 
alert(d);
或者
var d = new Date("2011-02-07T11:05:00");   
alert(d);
在 IE 中你会得到 ‘NaN’ ,在Safari 中你会得到 ‘Invalid Date’.  

但是Firefox、Chrome 、Opera 浏览器中会得到你想要的结果。

解决方案
解决在于你怎么选择传给Date()的参数.  
上文提到的两种浏览器(IE和Safari)不支持“yyyy-mm-dd”这种传参方式
但是下面提到的方法都可以兼容各种浏览器
var d = new Date(2011, 01, 07); // yyyy, mm-1, dd
var d = new Date(2011, 01, 07, 11, 05, 00); // yyyy, mm-1, dd, hh, mm, ss
var d = new Date("02/07/2011"); // "mm/dd/yyyy"
var d = new Date("02/07/2011 11:05:00"); // "mm/dd/yyyy hh:mm:ss"
var d = new Date(1297076700000); // milliseconds
var d = new Date("Mon Feb 07 2011 11:05:00 GMT"); // ""Day Mon dd yyyy hh:mm:ss GMT/UTC

下文是博客主写的

这里是我其实我测试到第三种("02/07/2011")才发现可以兼容edge
下文是我写的一个html(从一个已知的父母上什么班的天数推算到今日)
为的是能在手机上查看我爸妈今天是上什么班(爸妈都是很辛苦的倒班)
来决定能不能给家里打电话 = =

<!DOCTYPE html>
    <head>
        <meta  charset="UTF-8">
        <title>计算爸妈今天上什么班</title>
        <script>
            function Date2Str(Date){    //Date是Date类型的
                var strMonth = (Date.getMonth()+1).toString();
                var strDate = (Date.getDate()).toString();
                var strYear = Date.getFullYear().toString();
                var strToday = strMonth + "/" + strDate + "/" + strYear;
                return strToday;
            }
            function  DateDiff(Date1,  Date2){//Date1和Date2是Date类型的,缺交换天数的功能
                str1 = Date2Str(Date1);
                document.write("今天是"+str1+"<br />");
                str2 = Date2Str(Date2);
                document.write("上次我长记性是"+str2+"<br />");
                iDays  =  ((Date.parse(str1)- Date.parse(str2))/1000/60/60/24);    
                //把相差的毫秒数转换为天数  
                return  iDays;
           }
            var init = new Date("09/27/2015");
            
            var today = new Date();
            interval = DateDiff(today, init);
            document.write("相隔:"+interval+"天\n");
            var Period = 8;
            var mod = interval%Period;
            if( mod == 0){
                document.write("我妈下夜班 我爸休息");
            }
            else if(mod == 1){
                document.write("我妈休息 我爸白班");
            }
            else if(mod == 2){
             document.write("我妈白班 我爸上夜班");
            }
            else if(mod == 3){
             document.write("我妈上夜班 我爸下夜班");
            }
            else if(mod == 4){
             document.write("我妈下夜班 我爸白班");
            }
            else if(mod == 5){
             document.write("我妈休息 我爸上夜班");
            }
            else if(mod == 6){
             document.write("我妈白班 我爸下夜班");
            }
            else if(mod == 7){
             document.write("我妈上夜班 我爸休息");
            }
        </script>
    </head>
    <body>

    </body>


若想在错误响应返回 JSON,你可以使用 Rust 的 `actix-web` 框架来方便地构建 JSON 响应。以下是一个示例,演示如何使用 `actix-web` 在错误响应返回 JSON: ```rust use actix_web::{HttpResponse, http::StatusCode}; use serde::Serialize; #[derive(Serialize)] struct ErrorBody { error: String, } fn handle_request() -> HttpResponse { // 构建错误响应 let error_body = ErrorBody { error: "Invalid request".to_string() }; let json_body = serde_json::to_string(&error_body).unwrap(); HttpResponse::build(StatusCode::BAD_REQUEST) .content_type("application/json") .body(json_body) } ``` 在上面的示例,我们首先定义了一个名为 `ErrorBody` 的结构体,并使用 `serde` 的 `Serialize` trait 来自动实现 JSON 序列化。然后,在 `handle_request` 函数,我们创建了一个 `ErrorBody` 实例,并使用 `serde_json::to_string()` 方法将其序列化为 JSON 字符串。 接下来,我们使用 `HttpResponse::build()` 方法构建一个 `HttpResponse` 对象,并设置错误状态码为 `StatusCode::BAD_REQUEST`。然后,使用 `content_type()` 方法设置响应的内容类型为 `"application/json"`,并使用 `body()` 方法将 JSON 字符串作为响应的主体内容。 这样,当你调用 `handle_request()` 函数时,它将返回一个带有 JSON 格式错误响应的 `HttpResponse` 对象。 希望这可以帮助到你!如果你有更多关于错误响应或 JSON 序列化的问题,请继续提问。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值