childNodesFirefox在处理childNodes没有过滤换行与空格。所以在初次使用的时候,得到效果不是预期的效果。
如下代码:
HTML
<
ul
class
="tbtn"
ID
="menuList"
>
< li class ="curr" id ="tabap3_btn_0" onclick ="tabit(this)" > 理财大学B </ li >
< li id ="tabap3_btn_1" onclick ="tabit(this)" > 名医讲堂 </ li >
< li id ="tabap3_btn_2" onclick ="tabit(this)" > 名医讲堂 </ li >
< li id ="tabap3_btn_3" onclick ="tabit(this)" > 名医讲堂 </ li >
< li class ="lst" id ="tabap3_btn_4" onclick ="tabit(this)" > 影坛热点 </ li >
</ ul >
< li class ="curr" id ="tabap3_btn_0" onclick ="tabit(this)" > 理财大学B </ li >
< li id ="tabap3_btn_1" onclick ="tabit(this)" > 名医讲堂 </ li >
< li id ="tabap3_btn_2" onclick ="tabit(this)" > 名医讲堂 </ li >
< li id ="tabap3_btn_3" onclick ="tabit(this)" > 名医讲堂 </ li >
< li class ="lst" id ="tabap3_btn_4" onclick ="tabit(this)" > 影坛热点 </ li >
</ ul >
JS
function
tabit(btn)
... {
var idname = new String(btn.id);
var s = idname.indexOf("_");
var e = idname.lastIndexOf("_")+1;
var tabName = idname.substr(0, s);
var id = parseInt(idname.substr(e, 1));
var tabNumber = btn.parentNode.childNodes.length; //IE和FF的值不同
for(i=0;i<tabNumber;i++)
...{
if(document.getElementById(tabName+"_div_"+i)!=null) //这里需要进行判断
...{
document.getElementById(tabName+"_div_"+i).style.display = "none";
document.getElementById(tabName+"_btn_"+i).style.backgroundImage = "url(pic/t-1-2.gif)";
document.getElementById(tabName+"_btn_"+i).style.borderBottomColor = "#D7F2DA";
document.getElementById(tabName+"_btn_"+i).style.cursor = "pointer";
}
}
document.getElementById(tabName+"_div_"+id).style.display = "block";
btn.style.backgroundColor = "#fff";
btn.style.borderBottomColor = "#fff";
btn.style.cursor = "default";
}
... {
var idname = new String(btn.id);
var s = idname.indexOf("_");
var e = idname.lastIndexOf("_")+1;
var tabName = idname.substr(0, s);
var id = parseInt(idname.substr(e, 1));
var tabNumber = btn.parentNode.childNodes.length; //IE和FF的值不同
for(i=0;i<tabNumber;i++)
...{
if(document.getElementById(tabName+"_div_"+i)!=null) //这里需要进行判断
...{
document.getElementById(tabName+"_div_"+i).style.display = "none";
document.getElementById(tabName+"_btn_"+i).style.backgroundImage = "url(pic/t-1-2.gif)";
document.getElementById(tabName+"_btn_"+i).style.borderBottomColor = "#D7F2DA";
document.getElementById(tabName+"_btn_"+i).style.cursor = "pointer";
}
}
document.getElementById(tabName+"_div_"+id).style.display = "block";
btn.style.backgroundColor = "#fff";
btn.style.borderBottomColor = "#fff";
btn.style.cursor = "default";
}
在IE上menuList的childNodes.length的值为5,而在Firefox值为11.因此我们在使用childNodes对象时需要先对其判断或去掉空格。