关于 Date() 函数在 iOS 中的一个小坑
bug
今天遇到了一个诡异的 bug 。一个 Vux 的日期选择组件在 PC 端和安卓端都能正常显示和使用,而在 iOS 端却不能正常出现。经过漫长的调试,终于发现问题出在这一行代码上:
var startDate = new Date('2017-5-3')
这行代码在 PC 端和安卓端都是正常的,而在 iOS 端则会提示 Invalid Date 无效日期。
原因
new Date(dateString) 实际上是调用了 Date.parse() 这个函数。关于这个函数, ECMAScript 规范规定:
如果一个字符串不符合标准格式,则函数可以使用任何由引擎决定的策略或解析算法。
Date.parse()对于因包含有无效元素而无法识别的ISO格式字符串或者日期应该返回NaN。
简单的说这个函数在不同的浏览器引擎中会存在偏差,导致对字符串的解析不一致或部分浏览器无法解析。问题应该就是出在这里!是 Safari 不能识别这串字符串。
经过测试,将代码改为如下样子:
var startDate = new Date('2017-05-03')
这样代码就可以 iOS 端正常运行了。坑爹的 Safari 。
本文介绍了一个Vux日期选择组件在iOS环境下无法正常显示的问题及其解决办法。问题源于Date()函数对日期字符串的不同解析方式,特别是在Safari浏览器上的表现。通过调整日期字符串格式解决了该问题。
9689





