手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >IE中createElement需要注意的一个问题
IE中createElement需要注意的一个问题
摘要:代码如下:复制代码代码如下:var$alertPanel=$(document.createElement("div"));$alertPa...

代码如下:

复制代码 代码如下:

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.函数名() 调父页面的方法。

【IE中createElement需要注意的一个问题】相关文章:

网页里控制图片大小的相关代码

jQuery判断一个元素是否可见的方法

Javascript动态创建表格及删除行列的方法

DIV任意拖动的问题

基于JavaScript实现图片点击弹出窗口而不是保存

javascript中createElement的两种创建方式

JS中Eval解析JSON字符串的一个小问题

Js的Array数组对象详解

多个iframe自动调整大小的问题

document.getElementById的一些细节

精品推荐
分类导航