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

2019-12-24,,,

代码如下:
复制代码 代码如下:
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://demo.jb51.net/js/IE-createElement/page1.htm
总结:

如果你想在IE6,IE7中创建一个父页面元素,那么你必须使创建元素属于父页面。
复制代码 代码如下:
var dummy = parent.document.createElement("div");
var t = parent.document.createElement("table");

在Firefox,IE8中,它允许在一个文档中创建要追加到另一个文档的元素。
所以在Firefox,IE8中,可以使用parent.document也可以使用document。

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

您可能感兴趣的文章:

  • createElement与createDocumentFragment的点点区别小结
  • javascript createElement()创建input不能设置name属性的解决方法
  • Javascript createElement和innerHTML增加页面元素的性能对比
  • createElement动态创建HTML对象脚本代码
  • getElementByID、createElement、appendChild几个DHTML元素
  • 动态加载js文件 document.createElement
  • document.createElement("A")比较不错的属性
  • document.createElement()用法
  • document.createElement()用法及注意事项(ff下不兼容)

《IE中createElement需要注意的一个问题.doc》

下载本文的Word格式文档,以方便收藏与打印。