首頁 > web前端 > js教程 > 主體

jquery有哪些追加元素的方法

php中世界最好的语言
發布: 2018-04-23 17:16:16
原創
3589 人瀏覽過

這次帶給大家jquery有哪些追加元素的方法,jquery追加元素的注意事項有哪些,下面就是實戰案例,一起來看一下。

一、after()和before()方法的區別

    after()-其方法是將方法裡面的參數加到jquery物件後面去;
    如:A.after(B)的意思是將B放到A後面去;
    before()-其方法是將方法裡面的參數加到jquery物件前面去。
    如:A.before(B)的意思是將A放到B前面去; 
 
二、insertAfter()和insertBefore()的方法的差異

#    其實是將元素對調位置;
    可以是頁面上已有元素;也可以是動態加入的元素。
    如:A.insertAfter(B);即將A元素調換到B元素後面;
    如CC

HELLO

使用$("span>

HELLO

使用$("span>

HELLO

使用$("span") .insertAfter($("p"))後,就變成

HELLO

CC了。兩者位置交換了
 
三、append()和appendTo()方法的差異

    append()-其方法是將方法裡面的參數加入jquery物件中來;
    如:A.append(B)的意思是將B放到A中來,後面追加,A的子元素的最後一個位置;
    appendTo()-其方法是將jquery物件加入appendTo指定的參數中去。
    如:A.appendTo(B)的意思是將A放到B中去,後面追加,B的子元素的最後一個位置;
 
四、prepend()和prependTo ()方法的差異

    append()-其方法是將方法裡面的參數加入jquery物件中來;
    如:A.append(B)的意思是將B放到A中來,插入到A的子元素的第一個位置;
    appendTo()-其方法是將jquery物件加入appendTo指定的參數中去。
    如:A.appendTo(B)的意思是將A放到B中去,插入到B的子元素的第一個位置;
 
例子

#1、insert局部方法

/**
 * 在父级元素上操作DOM
 * @param {Object} parent  父级元素,可以是element,也可以是Yquery对象
 * @param {String} position 位置: beforebegin/afterbegin/beforeend/afterend
 * @param {*}   any   任何:string/text/object
 * @param {Number} index  序号,如果大于0则复制节点
 * @return {Undefined}
 * @version 1.0
 * 2013年12月2日17:08:26
 */
function _insert(parent, position, any, index) {
  if ($.isFunction(any)) {
    any = any.call(parent);
  }
  // 字符串
  if ($.isString(any)) {
    if (regTag.test(any)) {
      parent.insertAdjacentHTML(position, any);
    } else {
      parent.insertAdjacentText(position, any);
    }
  }
  // 数字
  else if ($.isNumber(any)) {
    parent.insertAdjacentText(position, any);
  }
  // 元素
  else if ($.isElement(any)) {
    parent.insertAdjacentElement(position, index > 0 ? any.cloneNode(!0) : any);
  }
  // Yquery
  else if (_isYquery(any)) {
    any.each(function() {
      _insert(parent, position, this);
    });
  }
}
登入後複製

2、append、prepend、before、after

$.fn = {
  /**
   * 追插
   * 将元素后插到当前元素(集合)内
   * @param {String/Element/Function} any
   * @return this
   * @version 1.0
   * 2013年12月29日1:44:15
   */
  append: function(any) {
    return this.each(function(index) {
      _insert(this, 'beforeend', any, index);
    });
  },
  /**
   * 补插
   * 将元素前插到当前元素(集合)内
   * @param {String/Element/Function} any
   * @return this
   * @version 1.0
   * 2013年12月29日1:44:15
   */
  prepend: function(any) {
    return this.each(function(index) {
      _insert(this, 'afterbegin', any, index);
    });
  },
  /**
   * 前插
   * 将元素前插到当前元素(集合)前
   * @param {String/Element/Function} any
   * @return this
   * @version 1.0
   * 2013年12月29日1:44:15
   */
  before: function(any) {
    return this.each(function(index) {
      _insert(this, 'beforebegin', any, index);
    });
  },
  /**
   * 后插
   * 将元素后插到当前元素(集合)后
   * @param {String/Element/Function} any
   * @return this
   * @version 1.0
   * 2013年12月29日1:44:15
   */
  after: function(any) {
    return this.each(function(index) {
      _insert(this, 'afterend', any, index);
    });
  }
};
登入後複製

3、prependTo、prependTo、insertBefore、insertAfter
這些帶有後綴的與上面的不同的是,傳回的結果不一樣。如:

$('#demo').append('<a/>');
// => 返回的是 $('#demo')
$('<a/>').appendTo($('#demo'));
// => 返回的是$('a');
登入後複製

因此兩者的關係只是返回結果不一樣,其他的都一樣,可以這麼解決:

_each({
  appendTo: 'append',
  prependTo: 'prepend',
  insertBefore: 'before',
  insertAfter: 'after'
}, function(key, val) {
  $.fn[key] = function(selector) {
    this.each(function() {
      $(selector)[val](this);
    });
    return this;
  };
});
登入後複製

jquery 追加元素的方法(append prepend after before 的區別)

append() 方法在被選元素的結尾插入內容。

prepend() 方法在被選元素的開頭插入內容。

after() 方法在被選元素之後插入內容。

before() 方法在被選元素之前插入內容。

<script type="text/javascript" src="http://common.jb51.net/jslib/jquery/jquery.min.js"></script>
<p class="testp">
  <ul>
    <li>第一个li标签</li>
  </ul>
</p>
<script>
  //append
  $('.testp ul').append('<li>append 插入的li</li>');
  //prepend
  $('.testp ul').prepend('<li>prepend 插入的li</li>');
  //after
  $('.testp ul').after('<li>after 插入的li</li>');
  //before
  $('.testp ul').before('<li>before 插入的li</li>');
</script>
登入後複製

效果圖

html結構圖

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

jquery如何刪除選取的css樣式

jQuery怎麼取得同級元素

以上是jquery有哪些追加元素的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板