处理浏览器的兼容问题之nextSibling

由于firefork浏览器在对nextSibling进行处理的时候,会把空白也当作节点。而IE不会。为了解决这个问题,方便调用,提供以下接口。下面是一个例子:

<html>
    <head>
        <meta charset="UTF-8">
        <title>ie与其他浏览器的处理</title>
    </head>
    <body>
        <ul>
            <li id="item1"></li>
            <li id="item2"></li>
            <li id="item3"></li>
        </ul>
        <script>
            function getNextNode(node){
                node=typeof node=="string" ? document.getElementById(node) : node ; 
                var nodeNext = node.nextSibling;
                if(!nodeNext) return null;
                if(!document.all){
                    while(true){
                        if(nodeNext.nodeType == 1){
                            break;
                        }else{
                            if(nodeNext.nextSibling){
                                nodeNext = nodeNext.nextSibling;
                            }else{
                                break;
                            }
                        }
                    }
                }
                return nodeNext;
            };
            var item = getNextNode("item1");
            alert(item.id);
        </script>
    </body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值