new Date()兼容ios

最近遇到了台历的组件在安卓手机上显示正常,但是苹果手机上根本alert不出值的问题
这个讲的比较细致,然后我就拿过来了~
带变量的表述  
var date = new Date(year+ "/" +yue+ "/01" );(-----这个不是我写的~~)


   在IOS5以上版本(不包含IOS5)中的Safari浏览器能正确解释出Javascript中的 new Date('2013-10-21') 的日期对象。
     但是在IOS5版本里面的Safari解释new Date('2013-10-21') 就不正确,在IOS5的Safari中返回的永远是"Invalid Date"。
     后来我在网上查找了资料,原来是低版本的Safari解释new Date('2013-10-21')这个对象不一样,在IOS5中的Safari不支持这种写法,
     而它支持的写法为new Date('2013','10','21'),这样写就能解决"Invalid Date"的问题,能返回一个Javascript Date回来了。
     但是随之而来的问题有出现了,Date是返回过来了,可是这个Date对象中方法返回的数据可不是我想要的,返回的数据全都不正确。具体是什么原因我也不太清楚,还请知道原理的大虾们指点下!
     现在返回过来的Date对象.getMonth()总要比正常的要多一个月!还有.getDay()返回的星期几也不正确!╮(╯▽╰)╭懊恼啊,折磨啊。。。。
     我都开始骂开发Safari的这帮人了,不过骂归骂问题还是要解决的,要不工资就木有了!呵呵!
     接着我查了很多国外的技术blog,终于找到了解决方案,原来想要IOS5中的Safari能正确解析new Date()那么必须这么写
     new Date('2013/10/21');   或者  

var d = new Date(date);
d = d.getFullYear() > 0 ? d : new Date(Date.parse(date.replace(/-/g, "/")));

 

自己写的一段代码

this.state.clearTime = setInterval(()=>{

let date = new Date();

//this.props.desk_start_time从后台获取的时间 '201612231933' 把他转化成 2016/12/23 19:33
       let dateT = this.props.desk_start_time.replace(/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/,"$1/$2/$3 $4:$5");
//以毫秒为单位所以要除1000
let dateTime = (date - new Date(dateT))/1000;
}).1000}


----------------谢谢作者--



IOS上只支持 yyyy/MM/dd 这种标准格式 IOS上只支持 yyyy/MM/dd 这种标准格式 IOS上只支持 yyyy/MM/dd 这种标准格式
引用\[1\]提供了一个兼容IOS的方法,用于将字符串转换为日期对象。该方法通过将字符串按照指定的分隔符进行分割,然后使用`new Date()`构造函数将分割后的数组元素作为参数传入,从而创建一个日期对象。这个方法可以解决IOS中`new Date()`对于特定格式的字符串的处理问题。引用\[2\]指出,在iPhone中,对于特定格式的字符串,如"2017-02-05 12:10:10.12",使用`new Date()`构造函数会返回"Invalid Date"的错误。为了解决这个问题,可以使用引用\[1\]中提供的兼容方法来处理日期字符串。引用\[3\]提供了将毫秒数转换为普通时间的方法。通过使用`getTime()`方法获取日期对象的毫秒数,然后将该毫秒数作为参数传入`new Date()`构造函数,就可以得到普通的时间。所以,如果你想在安卓手机上使用`new Date()`构造函数来处理日期字符串,你可以先检查字符串的格式是否符合安卓手机的要求,如果不符合,可以使用引用\[1\]中的兼容方法来处理日期字符串。如果符合要求,直接使用`new Date()`构造函数即可。 #### 引用[.reference_title] - *1* [苹果手机 new Date() 兼容问题处理](https://blog.csdn.net/weixin_44646763/article/details/128535494)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v88^control_2,239^v2^insert_chatgpt"}} ] [.reference_item] - *2* *3* [js日期毫秒的相互转化以及苹果手机new Date()兼容问题](https://blog.csdn.net/weixin_44609842/article/details/128437455)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v88^control_2,239^v2^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值