技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> JavaScript --> IE中createElement需要注意的一个小问题

IE中createElement需要注意的一个小问题

浏览:2063次  出处信息

    最近有读者求助,说在iframe中,创建一个元素,然后添加到父页面中在ie6,ie7中行不通,而firefox和IE8可以。

    代码如下:

    var $alertPanel = $( document.createElement(“div”) );

    $alertPanel.css(“width”,”120px”).css(“height”,”50px”).text(“Hello CssRain!”);

    $(‘body’,parent.document).append($alertPanel);

    顺着他的意思,我也写了个Demo,发现确实是这样。

    翻了翻资料,也没看到类似的问题。

    然后使用原生的DOM方法写了一次,发现也不行,一样。

    var div = document.createElement(“div”);

    div.style.width = “120px”;

    div.style.height = “50px”;

    div.style.border = “solid 1px #000000″;

    div.innerHTML = “Hello CssRain!”;

    parent.document.body.appendChild(div);

    于是想到既然appendChild要parent.document,那么创建的时候是否也要parent.document.createElement呢?

    于是把代码改成:

    var div = parent.document.createElement(“div”);

    div.style.width = “120px”;

    div.style.height = “50px”;

    div.style.border = “solid 1px #000000″;

    div.innerHTML = “Hello CssRain!”;

    parent.document.body.appendChild(div);

    这样就成功了, IE6和IE7能用。

    看例子:

    http://www.cssrain.cn/demo/IEcreateElement/page1.html

    总结:

    如果你想在IE6,IE7中创建一个父页面元素,那么你必须使创建元素属于父页面。

    var dummy = parent.document.createElement(“div”);

    var t = parent.document.createElement(“table”);

    …

    在Firefox,IE8中,它允许在一个文档中创建要追加到另一个文档的元素。

    所以在Firefox,IE8中,可以使用parent.document也可以使用document。

    另外google浏览器非常怪异,很乱。如果要兼容google浏览器,那么建议换种思路吧,比如直接用 parent.函数名() 调父页面的方法。

    来源:http://www.cssrain.cn/article.asp?id=1460

QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1