复制一个” <p>p元素</p>“到h2下面,怎么不会被包裹起来?

来源:5-5 DOM包裹wrapAll()方法

Candy3610866

2016-08-18 17:00

<body>

    <h2>DOM包裹wrapAll()方法</h2>

     <p>p元素</p>//问题:为什么这个P不会被包裹起来呢?

    <div class="left">

        <div class="aaron1">点击,通过wrapAll方法给所有P元素增加父容器div</div>

        <div class="aaron2">点击,通过wrapAll的回调方法给每个a元素增加父容器div</div>

    </div>

    <div class="right">

        <p>p元素</p>

        <p>p元素</p>

    </div>

    <div class="left">

        <a>a元素</a>

        <a>a元素</a>

    </div>

    <script type="text/javascript">

    $(".aaron1").on('click', function() {

        //给所有p元素,增加父容器div

        $('p').wrapAll('<div></div>');

    })

    </script>

    <script type="text/javascript">

    $(".aaron2").on('click', function() {

        //wrapAll接受一个回调函数

        //每一次遍历this都指向了合集中每一个a元素

        $('a').wrapAll(function() {

            return '<div></div>'

        })

    })

    </script>

</body>


写回答 关注

1回答

  • Candy3610866
    2016-08-18 17:16:34

    我知道了,因为wrapAll()会将所有匹配元素移动到第一个匹配元素的位置再进行包裹,将” <p>p元素</p>“复制到h2下面不是没有被包裹,而是所有的p都移到h2下面去了,不在”<div class="right">  </div>“内部了,没了.right的样式,我看不到了而已。。。好尴尬的自问自答



jQuery基础(二)—DOM篇

jQuery第二阶段开启DOM修炼,了解创建、插入、删除与替换

114012 学习 · 590 问题

查看课程

相似问题