IE 日期构造函数返回 NaN:跨浏览器日期转换解决方案
在 JavaScript 日期操作领域,出现了一个特殊问题Internet Explorer (IE) 中 Date 构造函数的行为与 Firefox 和 Chrome 中的同级构造函数不同。当尝试从字符串创建新的 Date 对象时,IE 返回 NaN(不是数字),而其他浏览器生成有效日期。
要理解这种差异,我们需要深入研究所使用的底层解析器机制由每个浏览器。在 IE 中,Date 构造函数难以处理某些日期格式,特别是那些包含逗号作为分隔符的日期格式。
以下是开发人员尝试构建日历时遇到的特定示例:
<code class="javascript">function buildWeek(dateText){ var headerDates=''; var newDate = new Date(dateText); for(var d=0;d<7;d++){ headerDates += '<th>' + newDate + '</th>'; newDate.setDate(newDate.getDate()+1); } jQuery('div#headerDates').html('<table><tr>'+headerDates+'</tr></table>'); }</code>
在在此函数中,dateText 参数表示本周的星期一,格式为“m, d, Y”(例如“02, 01, 2010”)。虽然这种格式在 Firefox 和 Chrome 中无缝运行,但在 IE 中却带来了挑战,因为 IE 无法正确解析逗号分隔值。
要解决此问题,我们可以使用更加一致且跨浏览器兼容的格式日期格式。其中一种方法是将逗号分隔的字符串转换为离散值数组,然后可以使用该数组构建有效的 Date 对象:
<code class="javascript">var dateStr="2011-08-03 09:15:11"; //returned from mysql timestamp/datetime field var a=dateStr.split(" "); var d=a[0].split("-"); var t=a[1].split(":"); var date = new Date(d[0],(d[1]-1),d[2],t[0],t[1],t[2]);</code>
在此示例中,dateStr 变量表示日期和从 MySQL 数据库检索的时间,格式为“YYYY-MM-DD HH:MM:SS”。通过将此字符串拆分为其组成部分并将它们单独传递给 Date 构造函数,我们确保跨浏览器一致地处理转换。
此解决方案解决了跨浏览器日期解析差异,并使 buildWeek 函数能够在所有主要浏览器中无缝工作,包括 Internet Explorer。
以上是IE 的日期构造函数是否会导致跨浏览器日期转换出现 NaN 错误?的详细内容。更多信息请关注PHP中文网其他相关文章!