欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

IE6-IE9中tbody的innerHTML不能賦值的解決方法

 更新時間:2014年06月05日 15:33:49   作者:  
這篇文章主要介紹了IE6-IE9中tbody的innerHTML不能賦值的解決方法,需要的朋友可以參考下
IE6-IE9中tbody的innerHTML不能賦值,重現(xiàn)代碼如下
復(fù)制代碼 代碼如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>IE6-IE9中tbody的innerHTML不能復(fù)制bug</title>
</head>
<body style="height:3000px">
<table>
<tbody>
<tr><td>aaa</td></tr>
</tbody>
</table>
<p>
<button id="btn1">GET</button><button id="btn2">SET</button>
</p>
<script>
var tbody = document.getElementsByTagName('tbody')[0]
function setTbody() {
tbody.innerHTML = '<tr><td>bbb</td></tr>'
}
function getTbody() {
alert(tbody.innerHTML)
}
btn1.onclick = function() {
getTbody()
}
btn2.onclick = function() {
setTbody()
}
</script>
</body>
</html>

兩個按鈕,第一個獲取tbody的innerHTML,第二個設(shè)置tbody的innerHTML。

獲取時所有瀏覽器都彈出了tr的字符串,但設(shè)置時IE6-9不支持,而且報錯,如圖
 
可以利用特性判斷來看瀏覽器是否支持tbody的innerHTML設(shè)值
復(fù)制代碼 代碼如下:

var isupportTbodyInnerHTML = function () {
var table = document.createElement('table')
var tbody = document.createElement('tbody')
table.appendChild(tbody)
var boo = true
try{
tbody.innerHTML = '<tr></tr>'
} catch(e) {
boo = false
}
return boo
}()
alert(isupportTbodyInnerHTML)

對于IE6-IE9里如果要設(shè)置tbody的innerHTML,可以使用如下替代方法
復(fù)制代碼 代碼如下:

function setTBodyInnerHTML(tbody, html) {
var div = document.createElement('div')
div.innerHTML = '<table>' + html + '</table>'
while(tbody.firstChild) {
tbody.removeChild(tbody.firstChild)
}
tbody.appendChild(div.firstChild.firstChild)
}

用一個div來包含一個table,然后刪除tbody里的所有元素,最后給tbody添加div的第一個元素的第一個元素,即div>table>tr。

當(dāng)然還有一個更精簡的版本,它直接采用replaceChild方法替換
復(fù)制代碼 代碼如下:

function setTBodyInnerHTML(tbody, html) {
var div = document.createElement('div')
div.innerHTML = '<table>' + html + '</table>'
tbody.parentNode.replaceChild(div.firstChild.firstChild, tbody)
}

從MSDN上記錄上看 col、colGroup、frameset、html、head、style、table、tfoot、tHead、title和tr的innerHTML都是只讀的(IE6-IE9)。

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

You can change the value of the title element using the document.title property.

To change the contents of the table, tFoot, tHead, and tr elements, use the table object model described in Building Tables Dynamically. However, to change the content of a particular cell, you can use innerHTML.

相關(guān)文章

  • js中AppendChild與insertBefore的用法詳細(xì)解析

    js中AppendChild與insertBefore的用法詳細(xì)解析

    這篇文章主要是對js中AppendChild與insertBefore的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • js實(shí)現(xiàn)百度登錄窗口拖拽效果

    js實(shí)現(xiàn)百度登錄窗口拖拽效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)百度登錄窗口拖拽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 詳解JWT token心得與使用實(shí)例

    詳解JWT token心得與使用實(shí)例

    這篇文章主要介紹了詳解JWT token心得與使用實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • js實(shí)現(xiàn)table添加行tr、刪除行tr、清空行tr的簡單實(shí)例

    js實(shí)現(xiàn)table添加行tr、刪除行tr、清空行tr的簡單實(shí)例

    下面小編就為大家?guī)硪黄猨s實(shí)現(xiàn)table添加行tr、刪除行tr、清空行tr的簡單實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • HTML+CSS+JavaScript創(chuàng)建一個簡單的井字游戲

    HTML+CSS+JavaScript創(chuàng)建一個簡單的井字游戲

    使用javascript創(chuàng)建游戲是最有趣的學(xué)習(xí)方式。它會讓你保持動力,這對于學(xué)習(xí)?Web?開發(fā)等復(fù)雜技能至關(guān)重要。本文將使用HTML、CSS和?Javascript創(chuàng)建一個井字游戲。感興趣的童鞋可以關(guān)注一下
    2021-11-11
  • 淺談js獲取ModelAndView值的問題

    淺談js獲取ModelAndView值的問題

    下面小編就為大家分享一篇淺談js獲取ModelAndView值的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • javascript 數(shù)組去重復(fù)(在線去重工具)

    javascript 數(shù)組去重復(fù)(在線去重工具)

    很多情況下我們需要去掉重復(fù)的內(nèi)容,一般我們都是將很多內(nèi)容放到一個數(shù)組里面,然后再去重復(fù),這里簡單為大家整理一下
    2016-12-12
  • 改進(jìn):論壇UBB代碼自動插入方式

    改進(jìn):論壇UBB代碼自動插入方式

    改進(jìn):論壇UBB代碼自動插入方式...
    2006-12-12
  • 使用js實(shí)現(xiàn)瀑布流效果

    使用js實(shí)現(xiàn)瀑布流效果

    這篇文章主要為大家詳細(xì)介紹了使用js實(shí)現(xiàn)瀑布流效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • js下寫一個事件隊(duì)列操作函數(shù)

    js下寫一個事件隊(duì)列操作函數(shù)

    異步操作可能會產(chǎn)生你不希望的事件觸發(fā)順序。這個問題以前也遇到過,當(dāng)時沒想太多,也就是直接多層嵌套(在ajax返回以后嵌套下一個事件)來解決。
    2010-07-07

最新評論