zoukankan      html  css  js  c++  java
  • extend

    这段时间在写一个预览图片的插件,

    被我老大说了无数次了,不多说啥,说多了都是泪

    昨天看着我的代码他说你用了extend,那你知道是什么意思吗

    我只知道是扩展的意思,瞬间觉得自己弱爆了

    真的

    然后今天看深究深究吧

    $.extend():可以合并多个对象,不行你看,这个也用到过

    今天在看ES6,然后加上最近一个review我发现web端可以用jQuery,来扩展对象,那因为我最近也在写小程序,就发现小程序并不能用jQuery,那我要是想扩展合并对象的话要怎么办呢,今天刚好看到一个Object.assign()

    var target={a:1}
    var srouce={a:3,b:4,c:5}
    
    var obj=Object.assign({},target,source)
    最后得到的obj是等于{a:3,b:4,c:5}

    也是跟extend一样的效果,也是碰到相同的属性的时候,后面的属性会覆盖前面的属性

    我前面加了一个{}空对象,也是跟extend一样,其实加不加都无所谓

              var defaults={
                        multis:1
                    };
                    var options = $.extend(opts,defaults, {});
                    console.log(options.multis);
                    opts = jQuery.extend({
                        imgType: ["gif", "jpeg", "jpg", "bmp", "png"],
    
                        // 布局方式 默认方式是平铺
                        present: 'full-fill',
                        multi: 1,
                         '',
                        height: '',
                    }, opts || {});

    options可以拿到defaults和opts的值

    这个要说明一下,要是重复的属性,会被覆盖掉

               var defaults={
                        multis:1,
                        multi:10
                    };
                    var options = $.extend(opts,defaults, {});
                    console.log(options.multi);
                    opts = jQuery.extend({
                        imgType: ["gif", "jpeg", "jpg", "bmp", "png"],
    
                        // 布局方式 默认方式是平铺
                        present: 'full-fill',
                        multi: 1,
                         '',
                        height: '',
                    }, opts || {});

    这样的时候options.multi会等于10,后面的值会覆盖前面的

    还有一个深层合并的,加了一个true,这个还没有用到过

    先是没有加true的:

     var test=$.extend({name:'lei',location:{city:'beijing'}},{last:'wen',location:{state:'china'}});
                    console.log(test)
    
    
    
    得到了
    
    Object
      last:
    "wen"
      location: Object
            state: "china"
            __proto__: Object
      name: "lei"
      __proto__: Object__defineGetter__: __defineGetter__()__defineSetter__: __defineSetter__()__lookupGetter__: __lookupGetter__()__lookupSetter__: __lookupSetter__()constructor: Object()hasOwnProperty: hasOwnProperty()isPrototypeOf: isPrototypeOf()propertyIsEnumerable: propertyIsEnumerable()toLocaleString: toLocaleString()toString: toString()valueOf: valueOf()get __proto__: __proto__()set __proto__: __proto__()

    要是加了true呢

      var test=$.extend(true,{name:'lei',location:{city:'beijing'}},{last:'wen',location:{state:'china'}});
                    console.log(test)
    
    
    
    Object
        last:"wen"
        location:
        Object
            city:"beijing"
            state:"china"
            __proto__ :Object
        name :"lei"
         __proto__:Object                           

    $.extend(还可以添加静态方法)这就是jquery.fn.extend{imgPreview:function()}这个就是我现在用到的了

    $.extend({
    
      add:function(a,b){return a+b},
    
      minu:function(a,b){return a-b}
    
    })
    
    var num=$.add(4,5)+$.minu(6,4);
    
    console.log(num)//11

     然后刚才偶然间又看到某个大神的文章

    然后上面有一段代码是这样的,我觉得特别通俗易懂

    ;(function($){
            $.fn.extend({
                Firstplus: function() {}
            });
    
            //这样写的话插件的使用方法就是:$('div').Firstplus();
    
            $.extend({
                Secondplus: function() {}
            });
            //这样写的话插件的使用方法就是:$.Secondplus();
        })($);

     这样就让我瞬间明白写插件的时候调用的方式

  • 相关阅读:
    Linux系统负载
    full nat
    close wait 状态的随想
    记录一下 性能分析问题
    golang 反射
    socket里面那个又爱又恨的锁
    Difference between skbuff frags and frag_list
    浅析TCP协议---转载
    http 怎样关闭
    http 响应 ngx_http_send_header ngx_http_output_filter
  • 原文地址:https://www.cnblogs.com/lwwen/p/6210398.html
Copyright © 2011-2022 走看看