javascript innerHTML出現未知執行階段錯誤

來源:互聯網
上載者:User

通過innerHTML來添加介面元素。
舉例。
.html
<table id="tab_1" width="100%" border="0"></table>

.js
document.getElementById("tab_1").innerHTML="<tr><td colspan="5"><div class="Double"><span>some:</span></div></td></tr>";
在IE中,有時候會出現"未知的執行階段錯誤(unknown runtime error)",
而在firefox裡不會。

這主要是IE在對innerHTML進行寫操作的時候會檢查tab_1是否具備做為這些內容中html對象容器的要求,所以如果你發現這些錯誤出現,嘗試做兩件事情:

1、檢查你嘗試加到innerHTML的html代碼是否包含破損的html標籤,如沒有<ul></ul>包圍的<li></li>.
2、把你的容器改成那些比較“包容”的標籤,如<span></span>,<div></div>

特別注意的是<tbody>,<table>,<tr>標籤裡面加正確格式的<td>標籤都有可能出錯,所以應該避免使用這些標籤作為容器。
必要時可以用<td>作為容器,再鍥套一層表格

 

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

原因有兩個
1.元素的innerHTML 屬性是唯讀。。
唯讀元素:COL, COLGROUP, FRAMESET, HEAD, HTML, STYLE, TABLE, TBODY, TFOOT, THEAD, TITLE, TR

2.HTML錯誤的嵌套例如在p裡嵌套div那修改div的innerHTML 屬性也會出現錯誤

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.