IE6/IE7/IE8/IE9中tbody的innerHTML不能赋值的完美解决方案
IE6/IE7/IE8/IE9中tbody的innerHTML不能赋值,重现代码如下
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8"/>
<title>IE6-IE9中tbody的innerHTML不能复制bug</title>
</head>
<body>
可以利用特性判断来看浏览器是否支持tbody的innerHTML设值
varisupportTbodyInnerHTML=function(){
vartable=document.createElement('table')
vartbody=document.createElement('tbody')
table.appendChild(tbody)
varboo=true
try{
tbody.innerHTML='<tr></tr>'
}catch(e){
boo=false
}
returnboo
}()
alert(isupportTbodyInnerHTML)
对于IE6-IE9里如果要设置tbody的innerHTML,可以使用如下替代方法
functionsetTBodyInnerHTML(tbody,html){
vardiv=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。
当然还有一个更精简的版本,它直接采用replaceChild方法替换
functionsetTBodyInnerHTML(tbody,html){
vardiv=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)。
TheinnerHTMLpropertyisread-onlyonthecol,colGroup,frameSet,html,head,style,table,tBody,tFoot,tHead,title,andtrobjects.
Youcanchangethevalueofthetitleelementusingthedocument.titleproperty.
Tochangethecontentsofthetable,tFoot,tHead,andtrelements,usethetableobjectmodeldescribedinBuildingTablesDynamically.However,tochangethecontentofaparticularcell,youcanuseinnerHTML.