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.
热门推荐
10 给女儿祝福语简短精辟
11 香薰的寓意祝福语简短
12 幼儿老师过年简短祝福语
13 团体年会祝福语简短霸气
14 明天早上祝福语简短的话
15 小清新的祝福语简短
16 中考物理加油祝福语简短
17 幽默的离职祝福语简短
18 姨父生日祝福语简短精辟