作家
登录

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

作者: 来源:www.28hudong.com 2013-03-30 01:27: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.函数名() 调父页面的方法。

  推荐阅读

  IE8 chrome中table隔行换色解决办法

IE8以上的版本代码,只需要CSS即可 tr{ background-color:expression('#F8F8F8,#EFEFEF'.split(',')[rowIndex%2]); } IE8以下的版本代码,是需要CSS与JS共同完成的: 首先定义好两个CSS,代码如下: 复制代码 代码>>>详细阅读


本文标题:IE中createElement需要注意的一个问题

地址:http://www.17bianji.com/kaifa2/JS/26047.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)