• 技术文章 >web前端 >js教程

    jquery有哪些追加元素的方法

    php中世界最好的语言php中世界最好的语言2018-04-23 17:16:16原创2263
    这次给大家带来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元素后面;
    如<span>CC</span><p>HELLO</p>使用$("span").insertAfter($("p"))后,就变为<p>HELLO</p><span>CC</span>了。两者位置调换了

    三、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中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    快捷开发Web应用及小程序:点击使用

    支持亿级表,高并发,自动生成可视化后台。

    专题推荐:jquery 方法 元素
    上一篇:asp.net+jquery.form做出图片异步上传功能 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 一文聊聊Node中的fs文件模块和path路径模块(案例分析)• 实例JavaScript之实现数值的动态变化• 一文聊聊Node.js中的进程与子进程• 一文教你JavaScript如何实现分支优化• 一文详解Node.js中的npm与包【万字教程】
    1/1

    PHP中文网