zoukankan      html  css  js  c++  java
  • 【javascript基础】IE6IE9不支持table.innerHTML的解决方法分享【转】

    IE6-IE9不支持table.innerHTML的解决方法分享

    测试代码:

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

    上述代码在IE6-9中无效,直接报错:
      IE9:Invalid target element for this operation.
      IE6-8:Unknown runtime error
      查找IE的文档(http://msdn.microsoft.com/en-us/library/ms533897(VS.85).aspx)后发现有这么一段:

    TheinnerHTMLproperty is read-only on thecol,colGroup,frameSet,html,head,style,table,tBody,tFoot,tHead,title, andtrobjects.

    所以只能用其他方案解,我的方案:

    var oTable=document.getElementById("test");
    //oTable.innerHTML="<tr><td>innerHTML</td></tr>";
    setTableInnerHTML(oTable,"<tr><td>innerHTML</td></tr>");
    
    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;
    }
    } 

    这里只是对table做了处理,对其他不支持的元素可以用类似的方案。

      另外,IE10中table已经支持innerHTML了。

    转自:

    http://www.jb51.net/article/31267.htm

  • 相关阅读:
    使用nginx搭建https服务器
    CentOS6.*安装gitolite
    Nginx 下配置SSL证书的方法
    Nginx Location配置总结
    最优二叉树(哈夫曼树)知识点
    utf8字节
    utf8字节
    nginx 配置日志
    nginx 配置日志
    elk 索引
  • 原文地址:https://www.cnblogs.com/sniper007/p/2848939.html
Copyright © 2011-2022 走看看