【JavaWeb】DOM操作-childNodes

在做DOM操作的练习-下拉列表左右选择时,使用了childNodes属性,不明白为什么select的子节点是7个。

正如绿色字体,不明白为什么会是7个,明明leftSelect下面是6个子节点啊(3个标签+3个文本),后来经过尝试和查阅才明白,select的childNodes是把元素节点后面跟的回车符,默认为一个文本节点,所以最终是7个(3个标签+4个文本)。

后来尝试一下,如果我把换行撤掉,那么childNodes的length即为6个。

我的代码:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>列表左右选择</title>
    </head>
    <body>
        <table border="1" width="600" align="center">
            <tr>
                <td>
                    分类名称
                </td>
                <td>
                    <input type="text" name="cname" value="手机数码"/>
                </td>
            </tr>
            <tr>
                <td>
                    分类描述
                </td>
                <td>
                    <textarea name="cdesc" rows="4" cols="20">手机数码类商品</textarea>
                </td>
            </tr>
            <tr>
                <td>
                    分类商品
                </td>
                <td>
                    <span style="float: left;">
                        <font color="green" face="宋体">已有商品</font><br/>
                        <select id="leftSelect" multiple="multiple" style="width: 100px;height: 200px;">
                            <option>IPhone6s</option>
                            <option>小米4</option>
                            <option>锤子T2</option>
                        </select>

                        <p><a href="#" style="padding-left: 20px;" οnclick="leftToRightOne()">&gt;</a></p>
                        <p><a href="#" style="padding-left: 20px;" οnclick="leftToRightSelect()">&gt;&gt;</a></p>
                        <p><a href="#" style="padding-left: 20px;" οnclick="leftToRightAll()">&gt;&gt;&gt;</a></p>
                    </span>
                    <span style="float: right;">
                        <font color="red" face="宋体">未有商品</font><br/>
                        <select id="rightSelect" multiple="multiple" style="width: 100px;height: 200px;">
                            <option>三星Note3</option>
                            <option>华为6s</option>
                        </select>

                        <p><a href="#" >&lt;</a></p>
                        <p><a href="#" >&lt;&lt;</a></p>
                        <p><a href="#" >&lt;&lt;&lt;</a></p>
                    </span>
                </td>
            </tr>
            <tr>
                <td colspan="2">
                    <input type='submit' value="修改"/>
                </td>
            </tr>
        </table>
        <script>
            /**
             * 此处使用childNodes获得所有节点,也可以使用<select>标签特有的属性options获得所有的<option>子标签
             */
            function leftToRightOne(){
                var leftSelect = document.getElementById("leftSelect");
                var rightSelect = document.getElementById("rightSelect");
//                alert(leftSelect.childNodes[1].nodeName);
                for(var i=0;i<leftSelect.childNodes.length;i++){
                    if(leftSelect.childNodes[i].selected){
                        rightSelect.appendChild(leftSelect.childNodes[i]);
                        break;
                    }
                }
            }
            
            /**
             * leftSelct.childNodes.length最终长度为7,获得4个text文本,3个option
             * 元素:text、option[1]、text、option[2]、text、option[3]、text
             * 当遍历时,第一个option移除后,length变成了6,此时i==2,正好是第二个option
             * 移除第二个后,此时i=3,正好是第三个option,所以可以正常移动所有
             */
            function leftToRightSelect(){
                var leftSelect = document.getElementById("leftSelect");
                var rightSelect = document.getElementById("rightSelect");
//                alert(leftSelect.childNodes.length);
//                console.log(leftSelect.childNodes)
//                for(var i=0;i<leftSelect.childNodes.length;i++){
//                    alert(leftSelect.childNodes[i].nodeName);
//                }
                for(var i=0;i<leftSelect.childNodes.length;i++){
                    if(leftSelect.childNodes[i].selected){
                        rightSelect.appendChild(leftSelect.childNodes[i]);
                    }
                }
            }
            
            /**
             * 方式一:子元素和文本同时都移动
             */
//            function leftToRightAll(){
//                var leftSelect = document.getElementById("leftSelect");
//                var rightSelect = document.getElementById("rightSelect");
//                for(var i=0;i<leftSelect.childNodes.length;i++){
//                    rightSelect.appendChild(leftSelect.childNodes[i]);
//                    i--;//因为length是不断变化的,保证一直移除第一个
//                }
//            }
            
            /**
             * 方式二:length不断变化,i不需要变化
             */
//            function leftToRightAll(){
//                var leftSelect = document.getElementById("leftSelect");
//                var rightSelect = document.getElementById("rightSelect");
//                for(var i=0;i<leftSelect.childNodes.length;){
//                    rightSelect.appendChild(leftSelect.childNodes[i]);
//                    //因为length是不断变化的,保证一直移除第一个
//                }
//            }
            /**
             * 方式三:采用倒序,不过右边内容也是倒序的
             */
            function leftToRightAll(){
                var leftSelect = document.getElementById("leftSelect");
                var rightSelect = document.getElementById("rightSelect");
                for(var i = leftSelect.childNodes.length-1;i>=0;i--){
                    rightSelect.appendChild(leftSelect.childNodes[i]);
                }
            }
        </script>
    </body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值