IE中createElement需要注意的一个小问题
最近有读者求助,说在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
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:robot 来源: UED TEAM
- 标签: createElement
- 发布时间:2010-06-27 22:30:03
- [67] Oracle MTS模式下 进程地址与会话信
- [65] 如何拿下简短的域名
- [65] Go Reflect 性能
- [59] 图书馆的世界纪录
- [59] 【社会化设计】自我(self)部分――欢迎区
- [59] android 开发入门
- [58] IOS安全–浅谈关于IOS加固的几种方法
- [53] 视觉调整-设计师 vs. 逻辑
- [47] 读书笔记-壹百度:百度十年千倍的29条法则
- [47] 界面设计速成