javascript - 我想移动div节点,但是怎么移动?
巴扎黑
巴扎黑 2017-04-11 09:02:12
[JavaScript讨论组]
<p class="x">
    <p  class="x1">111</p>
    <p  class="x1">222</p>
    <p  class="x1">333</p>
</p>
<script>
    function cla(element){
        return document.getElementsByClassName(element);
    }
    function $(element){
        return document.getElementById(element);
    }

    function xx(){
        $("x").insertBefore(cla("x1")[1],cla("x1")[0])
    }
    xx();
</script>

我一开始想到的是insertBefore(),但是这个怎么用?为何我这里报错?

还有什么办法能真正移动节点吗?

巴扎黑
巴扎黑

全部回复(2)
PHP中文网

示例:

    <p class="x">
        <p class="x1">111</p>
        <p class="x1">222</p>
        <p class="x1">333</p>
    </p>
    <script src="https://cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>
    <script>
        $('p').insertBefore('.x');
        //或者
         $('.x').insertBefore('p');
    </script>

**你上面那些函数有个getElementById(element)
但是你的标签里哪有ID?**

原生JS使用方式

        var x = document.getElementsByClassName('x')[0];
        var p = document.getElementsByTagName('p')[0];
        x.insertBefore(p, x.childNodes[0]);//第一个参数:要插入的标签,第二个参数:在哪个标签之前插入

如果直接改你的代码就是:

<p class="x" id="x"> //加上ID

js改成

$("x").insertBefore(cla("x1")[1], $("x").childNodes[0]);
巴扎黑

纠正一下、
你的$()方法里面写的是ID选择节点

可是你调用的是class名
具体

function $(element){
    return document.getElementById(element);
}
 $("x")
 <p class="x">
 

看到错误就想指出了

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号