ie6-ie9中不支持table.innerHTML的问题

测试代码:


<table id="test">
</table>
<script>
    var oTable=document.getElementById("test");
    oTable.innerHTML="<tr><td>innerHTML</td></tr>";
</script>

上述代码在IE6-9中无效 (IE10正常),直接报错:

  IE9:Invalid target element for this operation.

  IE6-8:Unknown runtime error

查看msdn文档http://msdn.microsoft.com/en-us/library/ms533897(VS.85).aspx有这样一段描述:

The innerHTML property is read-only on the col, colGroup, frameSet, html, head, style, table, tBody, tFoot, tHead, title, and tr objects.

原来在ie6-ie9中table的innerHTML是只读的。 解决方法:

function setTableInnerHTML(table, html) {
   if(navigator&&navigator.userAgent.match(/msie/i)){
      var temp = table.ownerDocument.createElement('div');
      temp.innerHTML = '<table><tbody>' + html + '</tbody></table>';
      if(table.tBodies.length == 0){
         var tbody=document.createElement("tbody");
         table.appendChild(tbody);
      }
      table.replaceChild(temp.firstChild.firstChild, table.tBodies[0]);
   }else{
      table.innerHTML=html;
   }
}

var objtable=document.getElementById('devicelisttable')
var thead=objtable.rows[0].parentNode.innerHTML
setTableInnerHTML(objtable, thead+iteminfo.join(''))
这里只是对table做了处理,对其他不支持的元素可以用类似的方案。另外,IE10中table已经支持innerHTML了。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值