2-8 内部插入
本节编程练习不计算学习进度,请电脑登录imooc.com操作

内部插入

jQuery针对DOM操作的插入的方法有大概10种:

append、prepend、before、after、replaceWith
appendTo、prependTo、insertBefore、insertAfter、replaceAll

分2组,上下对照,实现同样的功能。主要的不同是语法——特别是内容和目标的位置。

依赖的domManip,buildFragment模块在之前就分析过了。

在匹配元素集合中的每个元素后面插入参数所指定的内容,作为其兄弟节点。

对于 .after(), 选择表达式在函数的前面,参数是将要插入的内容。

对于 .insertAfter(),刚好相反,内容在方法前面,它将被放在参数里元素的后。

After

after: function() {
    return this.domManip( arguments, function( elem ) {
        if ( this.parentNode ) {
            this.parentNode.insertBefore( elem, this.nextSibling );
        }
    });
},

之前提过了所有的方法靠this.domManip合并参数处理,内部通过buildFragment模块构建文档碎片,然后把每一个方法的具体执行通过回调的方式提供出来处理。

DOM操作并未提供一个直接可以在当前节点后插入一个兄弟节点的方法,但是提供了一个类似的方法。

insertBefore() 方法:可在已有的子节点前插入一个新的子节点。

语法 :insertBefore(newchild,refchild)

看看jQuery如何处理的,例如:

inner.after('<p>Test</p>');

内部就会把  '<p>Test</p>' 通过buildFragment构建出文档elem,然后通过 this.parentNode.insertBefore( elem, this.nextSibling );

这里的this 就是对应着inner ,elem就是‘<p>Test</p>’,看到这里就很好理解after的实现了。

用原生方法简单模拟:右侧代码编辑器所示。

insertAfter

$('<p>Test</p>').insertAfter('.inner');

通过$('<p>Test</p>')构建一个文档,对象通过insertAfter方法插入到所有class等于inner的节点后。表达的意思与after是一样的,主要的不同是语法——特别是内容和目标的位置。

看具体的实现方法中insertAfter('.inner');inner其实就被当作selector传入进来了,selector可能只是字符串选择器内部就需要转化,insert = jQuery( selector ),

$('<p>Test</p>')就是构建出来的文档碎片节点,那么如果赋给insert有多个的时候就需要完全克隆一份副本了,所以就直接赋给:

elems = i === last ? this : this.clone( true );
jQuery( insert[ i ] )[ original ]( elems );

依旧是执行after:

jQuery( insert[ i ] )[ original ]( elems );

最终还需要返回这个构建的新节点。

收集构建的节点:

core_push.apply( ret, elems.get() );

构建一个新jQuery对象,以便实现链式:

this.pushStack( ret );

可见 after 与 insertAfter 本质其实都是一样的,只是通过不同的方式调用。

任务

  1. <!doctype html>
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-type" content="text/html; charset=utf-8"/>
  5. <script src="http://code.jquery.com/jquery-latest.js"></script>
  6. <title>DOM操作</title>
  7. </head>
  8. <body>
  9.  
  10. <button id="test1">模拟after处理</button>
  11.  
  12.  
  13. <div class="container">
  14. <h2>Greetings</h2>
  15. <div class="inner">Hello</div>
  16. <div class="inner">Goodbye</div>
  17. </div>
  18.  
  19.  
  20. <script type="text/javascript">
  21.  
  22. $('#test1').click(function() {
  23. var inner = document.getElementsByClassName('inner')
  24. for (var i = 0; i < inner.length; i++) {
  25. var elem = inner[i]
  26. var div = document.createElement('div')
  27. div.innerHTML = 'aaaa'
  28. elem.parentNode.insertBefore(div, elem.nextSibling)
  29. }
  30. })
  31.  
  32.  
  33. </script>
  34.  
  35. </body>
  36. </html>
下一节