JavaScript中IE兼容出现的问题及解决方法


本文摘自PHP中文网,作者不言,侵删。

本篇文章给大家带来的内容是关于JavaScript中IE兼容出现的问题及解决方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

在IE浏览器中出现的问题

1、不能执行已释放 Script 的代码

1、bug出现背景:

在使用iframe标签时,如果子页面向父页面传递在子页面创建的对象(所有对象,包括数组,函数,正则等)时,会出现这个bug。

2、bug出现原因:

在子页面关闭时,会释放掉在子页面中声明赋值的对象。所以在父页面所有对这个对象的引用操作都会产生这个JS错误。

3、解决方法有2种:

第一,在父页面把所有对象都建好,在子页面对这个对象进行字符串赋值。
第二,如果子页面产生的对象数量是不定的,使用JSON.stringfy()把要回传的对象变成字符串。然后在父页面中使用JSON.parse()变成对象。

IE、firefox浏览器下JS的new Date()的值为Invalid Date、NaN-NaN

截图信息

1471032418-5c98897ec58e3_articlex.png

1、问题出现背景:
在IE浏览器中,使用new Date("xxxx")方法,将一串日期字符串转换为具体的Date格式的时,会出现这个问题。如:
new Date("2019-03-21 10:41:33") //[date] Invalid Date[date] Invalid Date
但是这个方法却在谷歌浏览器上可以返回正确的结果。

2、问题出现原因:

字符串的格式不被IE浏览器识别,而导致的

3、解决方法:

new Date("2019/03/21 10:41:33") //[date] Thu Mar 21 2019 10:41:33 GMT+0800 (中国标准时间)[date] Thu Mar 21 2019 10:41:33 GMT+0800 (中国标准时间)

备注:在使用的时候,我们可以通过字符串转换的方式,将日期字符串格式转换为浏览器支持的格式,在使用new Date()。

1

2

3

var date = '2019-03-21 10:41:33';

date = date.replace(new RegExp(/-/gm) ,"/");   //将所有的'-'转为'/'即可

Date d=new Date(date);

4、总结

阅读剩余部分

相关阅读 >>

7个javascript中关于闭包的面试题,你能回答上来吗?

nw.js的localstorage的物理储存实例详解

javascript:世界上最被误解的语言

javascript是网络协议吗

webpack如何实现loader?(附代码)

javascript有split函数吗

javascript中settimeout()和setinterval()两个定时器的区别

content-type几种值的区别及用法介绍

javascript中如何声明变量

用h5的webgl如何在同一个界面做出json和echarts图表

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...