javascript中兼容主流浏览器的动态生成iframe方法_javascript技巧
程序员文章站
2022-04-25 13:13:06
...
以下代码在IE8下运行通过,在IE9中出错:
document.createElement('');
错误提示:exception : SCRIPT5022: DOM Exception: INVALID_CHARACTER_ERR (5)
var oFrame = isIE ? document.createElement("
var isIE = (document.all) ? true: false; //这里仅仅简单的对是否是IE进行判断,详细浏览器判断:请参考浏览器类型侦测
var ua = navigator.userAgent.toLowerCase().match(/msie ([/d.] + ) / )[1];
if (ua == "9.0") {
isIE = false;
}
var oFrame = isIE ? document.createElement("
复制代码 代码如下:
document.createElement('');
错误提示:exception : SCRIPT5022: DOM Exception: INVALID_CHARACTER_ERR (5)
思路分析:
第一步:兼容IE9,firefox,Opera,Safari等浏览器;
复制代码 代码如下:
var iframe = document.createElement("iframe");
iframe.setAttribute("id", "yui-history-iframe");
iframe.setAttribute("src", "../../images/defaults/transparent-pixel.gif");
iframe.setAttribute("style","position:absolute;top:0;left:0;width:1px;height:1px;visibility:hidden;");
iframe.setAttribute("id", "yui-history-iframe");
iframe.setAttribute("src", "../../images/defaults/transparent-pixel.gif");
iframe.setAttribute("style","position:absolute;top:0;left:0;width:1px;height:1px;visibility:hidden;");
第二步:兼容IE6-8:由于ie6-8 不能修改iframe的name属性
复制代码 代码如下:
var oFrame = isIE ? document.createElement("
综合解决办法:
复制代码 代码如下:
var isIE = (document.all) ? true: false; //这里仅仅简单的对是否是IE进行判断,详细浏览器判断:请参考浏览器类型侦测
var ua = navigator.userAgent.toLowerCase().match(/msie ([/d.] + ) / )[1];
if (ua == "9.0") {
isIE = false;
}
var oFrame = isIE ? document.createElement("
推荐阅读
-
JavaScript 动态生成方法的例子_javascript技巧
-
js 获取屏幕各种宽高的方法(浏览器兼容)_javascript技巧
-
浏览器解析js生成的html出现样式问题的解决方法_javascript技巧
-
JS兼容浏览器的导出Excel(CSV)文件的方法_javascript技巧
-
解决火狐浏览器下JS setTimeout函数不兼容失效不执行的方法_javascript技巧
-
IE浏览器中图片onload事件无效的解决方法_javascript技巧
-
动态创建样式表在各浏览器中的差异测试代码_javascript技巧
-
IE8中使用javascript动态加载CSS的解决方法_javascript技巧
-
js生成动态表格并为每个单元格添加单击事件的方法_javascript技巧
-
文本框中,回车键触发事件的js代码[多浏览器兼容]_javascript技巧