javascript IE10 兼容性问题

<script>varurl=document.location.href.toLowerCase();varp=document.getElementById('gzt... <script> var url=document.location.href.toLowerCase();var p=document.getElementById('gzt');for(i=1;i<p.childNodes.length;i++){ var c=p.childNodes[i]; var ahref=c.firstChild.href.toLowerCase(); if(url.indexOf(ahref)>-1) { c.className='k2'; break; }} </script>

如上文,在IE9 和IE10 下 这样调试var ahref=c.firstChild.href.toLowerCase();提示 SCRIPT5007: 无法获取未定义或 null 引用的属性“href”,没法实现相关效果,IE8是正常的,应用在如下的HTML 中(以下代码为多个页面公用的,而不是在一个页面上的table效果,是实现在不同页面上都有table效果。):
<style type=“text/CSS”>
#gzt li{float:left;height:26px;width:90px;text-align:center;background:url(gzt_tab2.gif);font:normal 14px/26px 'microsoft yahei'; list-style-type:none}#gzt .k1{width:38px;background:url(gzt_l.gif);}#gzt .k2{background:url(gzt_tab1.gif);font-weight:bold;}#gzt .k3{width:100px;background:url(gzt_tab3.gif)}
</style>
<ul id="gzt" > <li class="k1"></li><!--左侧图标--><!--带k2的就是当前栏目--><li ><a href="<计算的值>" >工作任务(<计算的值>)</a></li><li ><a href="<计算的值>" >待评阅(<计算的值>)</a></li><li ><a href="<计算的值>" >待修改(<计算的值>)</a></li><li ><a href="<计算的值>" >待签收(<计算的值>)</a></li><li ><a href="<计算的值>" >待出版(<计算的值>)</a></li><li ><a href="<计算的值>" >待绘图(<计算的值>)</a></li><li ><a href="<计算的值>" >待晒图(<计算的值>)</a></li><li ><a href="<计算的值>" >待办理(<计算的值>)</a></li><li ><a href="<计算的值>" >车辆(<计算的值>)</a></li> <li ><a href="<计算的值>" >日常用品(<计算的值>)</a></li> <li ><a href="<计算的值>" >工作进展</a></li> <li class="k3"></li><!--右侧图片--></ul>
正常的效果图如下:
展开
 我来答
渁龍蝎
2014-04-17 · TA获得超过241个赞
知道小有建树答主
回答量:179
采纳率:0%
帮助的人:122万
展开全部
第一个li和最后一个li中内容为空型友。所以卜辩槐c.firstChild为null,无法获取到c.firstChild.href属性。
在for循环中判断一下灶御
if(c.firstChild!=null&&c.firstChild!="undefind"){
var c=p.childNodes[i];
var ahref=c.firstChild.href.toLowerCase();
if(url.indexOf(ahref)>-1)
c.className='k2';
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式