IE 中"HTML Parsing Error:Unable to modify the parent container element before the

 

错误: IE 中"HTML Parsing Error:Unable to modify the parent container element before the child element is closed"

 

 

现象: 同事之间几个IE 测试情况下,有的报这个错,有的不报。经查询资料后,可归纳以下原因。

       1. 有未关闭的 html 标签,比如 <table> 而没有 </table>

       2. 在页面未加载完前 js 代码操作了 body 里的元素,将相关 js 代码移到 </body> 后面

 

我这里的原因是进行了某些 DOM 操作发生在 DOM 树加载完成之前,有 appendChild

<html>
<head>
</head>
<body>
<div>
<script type="text/javascript">
    alert(document.readyState);
    var oDiv = document.createElement("DIV");
    oDiv.innerHTML = 'test odiv test odiv';
    document.body.appendChild(oDiv);
</script>
</div>
</body>
</html>
 

---------------------------------------------------------------------------------------------------------------------------------

当解析到 DIV 时就开始在 BODYappendChild ,而这个时候 BODY 是还没有完全就绪的( It is not fully loaded ),文档结构仍在 loadinginteractive 状态之间,于是,便会得到上述错误

 

 

解决办法:

要解决这个问题,可以进行 document.readyState 状态判断,当它为 complete 时再进行相应的操作

 

if (document.readyState=="complete")
{

        createDiv ();

}
else
{
      document.onreadystatechange = function(){

                if (document.readyState == "complete")
                {
                        createDiv ();
                }

        }

}

function createDiv()
{
    var oDiv = document.createElement("DIV");
    oDiv.innerHTML = 'test odiv test odiv';
    document.body.appendChild(oDiv);

}
 

onreadystatechange :

 

存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。

 

readyState:

存有 XMLHttpRequest 的状态。从 0 4 发生变化。

  • 0: 请求未初始化
  • 1: 服务器连接已建立
  • 2: 请求已接收
  • 3: 请求处理中
  • 4: 请求已完成,且响应已就绪

 

0 - UNINITIALIZEDXML 对象被产生,但没有任何文件被加载。
1 - LOADING
:加载程序进行中,但文件尚未开始解析。
2 - LOADED
:部分的文件已经加载且进行解析,但对象模型尚未生效。
3 - INTERACTIVE
:仅对已加载的部分文件有效,在此情况下,对象模型是有效但只读的。
4 - COMPLETED
:文件已完全加载,代表加载成功。

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值