问答详情
源自:9-11 访问兄弟节点

运行结果: 前一个节点出不来

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>兄弟节点</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 a=n.previousSibling;
        while(a&&a.nodeType!=1){
            a=a.previousSibling;
        }
        return b;
    }

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

    var y=get_nextSibling(x);

    if(y!=null){
        document.write("<br />nextSibling: ");
        document.write(y.nodeName);
        document.write(" = ");
        document.write(y.innerHTML+"<br  /><br  />");
    }else{
        document.write("<br>已经是最后一个节点"+"<br /><br  />");
    }
    var a=document.getElementsByTagName("li")[2];
    document.write("</br>"+a.nodeName);
    document.write("=");
    document.write(a.innerHTML);
    var b=get_previousSibling(a);

    if(b!=null){
        document.write("</br>previousSibling");
        document.write(b.nodeName);
        document.write("=");
        document.write(b.innerHTML+"</br>")
    }else{
        document.write("这是第一个节点")
    }

</script>
</body>
</html>

运行结果:  前一个节点出不来

  • javascript

  • jquery

  • html

  • css3

  • php

  • java

LI = javascript
nextSibling: LI = jquery


LI=html这是第一个节点


提问者:qq_不善言_1 2019-09-13 10:18

个回答

  • qq_绅士_28
    2019-09-18 01:13:41

    function get_previousSibling(n) {
            var a=n.previousSibling;
            while(a&&a.nodeType!=1){
                a=a.previousSibling;
            }
            return b;
        }

    你的这个函数里没有b这个变量,你return b干嘛,改成a试一下咯