您的位置:首页 > 其它

IE9创建DOM元素开始严格遵循标准的实现!这次坑大发了

2012-12-20 11:49 806 查看
http://www.cnblogs.com/yuzhongwusan/archive/2012/07/12/2588226.html

IE9创建DOM元素的方式较之前有了改变,开始严格遵循标准的实现,不允许通过直接传入一个完整html标记的方式来创建Dom元素。

document.createElement('<iframe id="yui-history-iframe" src="http://images.cnblogs.com/defaults/transparent-pixel.gif" style="position:absolute;top:0;left:0;width:1px;height:1px;visibility:hidden;"></iframe>');

解决方法:

采用标准的方式来实现:

if( $.browser.msie &&/9.0/.test(navigator.userAgent)){

                var iframe = document.createElement("iframe");

                iframe.setAttribute("class","bgiframe");

                iframe.setAttribute("frameborder","0");

                iframe.setAttribute("style","display:block;position:absolute;z-index:-1;filter:Alpha(Opacity=\'0\');top:expression(((parseInt(this.parentNode.currentStyle.borderTopWidth)||0)*-1)+\'px\');left:expression(((parseInt(this.parentNode.currentStyle.borderLeftWidth)||0)*-1)+\'px\');width:expression(this.parentNode.offsetWidth+\'px\');height:expression(this.parentNode.offsetHeight+\'px\');");

                this.insertBefore( iframe,this.firstChild );

            }else{

                this.insertBefore( document.createElement(html),this.firstChild );

            }
 

 

________________zhuanzai_____________________________________________________________

 

 

以下代码在IE8下运行通过,在IE9中出错:

document.createElement('<iframe id="yui-history-iframe" src="http://images.cnblogs.com/defaults/transparent-pixel.gif" style="position:absolute;top:0;left:0;width:1px;height:1px;visibility:hidden;"></iframe>');

错误提示: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", "http://images.cnblogs.com/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("<iframe name=/"" + this._FrameName + "/">") : document.createElement("iframe");

oFrame.name = "iframName";

综合解决办法:

        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("<iframe name=/"" + this._FrameName + "/">") : document.createElement("iframe");

oFrame.name = "iframName";
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息