为了账号安全,请及时绑定邮箱和手机立即绑定

查找前一个兄弟节点,当前节点位置为0和1的时候都行,但是2不行,求帮忙

<!DOCTYPE HTML>

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8">

<title>nextSibling</title>

</head>

<body>

<ul id="u1">   

            <li id="a">javascript</li>   

            <li id="b">jquery</li>   

            <li id="c">html</li>   

        </ul>   

        <ul id="u2">   

            <li id="d">css3</li>   

            <li id="e">php</li>   

            <li id="f">java</li>   

        </ul>   

<script type="text/javascript">

    function get_nextSibling(n){

        var x=n.nextSibling;

        while (x && x.nodeType!=1){

            x=x.nextSibling;

        }

        return x;

    }

    

    function get_previousSibling(n){

        var x=document.getElementsByTagName("li")[0];

        var y=x.nextSibling;

        while(x!=n&&x.nextSibling!=n&&y.nextSibling!=n){

            document.write("<br>"+x.innerHTML+" "+y.innerHTML);

            if(y.nodeType!=1){

                document.write("1");

                x=x.nextSibling;

            }

            else{

                y=x.nextSibling;

               

            }

        }

        return x;

    }

    

    var x=document.getElementsByTagName("li")[2];

    document.write(x.nodeName);

    document.write(" = ");

    document.write(x.innerHTML);

    

    //var y=get_nextSibling(x);

    var y=get_previousSibling(x);

    

    if(y!=x){

        document.write("<br />nextsibling: ");

        document.write(y.nodeName);

        document.write(" = ");

        document.write(y.innerHTML);

    }else{

      document.write("<br>已经第一个节点");      

    }


</script>

</body>

</html>


正在回答

1 回答

首先吐槽一下你那个get_previousSibling函数写得莫名奇妙的,怎么就直接在函数体内定义一个固定的x对象了,然后还要用nextSibling这个属性啊...明明是找上一个兄弟节点,你用什么nextSibling????

https://img1.sycdn.imooc.com//5be10faf0001d87d09940668.jpg

你写的程序的流程是这样的。。所以当是2的时候就不行了,注意看代码注释,可能有点绕,但一定要自己想通这个过程。

下面是正确的get_previousSibling函数写法

https://img1.sycdn.imooc.com//5be1105d000134d105700407.jpg


0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

查找前一个兄弟节点,当前节点位置为0和1的时候都行,但是2不行,求帮忙

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信