美文网首页你不知道的JavaScriptJava 核心技术
详解Javasript设计模式之链式调用

详解Javasript设计模式之链式调用

作者: a333661d6d6e | 来源:发表于2018-11-29 19:33 被阅读0次

    本文主要为大家详细介绍了Javasript设计模式之链式调用的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

    写过jquery的可能都知道,jquery里面可以很方便的使用以下代码:

    // 不使用链式调用
    const element = $(ele);
    element.addClass('red');
    element.removeClass('green');
    element.show();
     
    // 链式调用
    $(ele)
     .addClass('red')
     .removeClass('green')
     .show();
    

    而jquery这种调用方式就是链式调用。我们可以从上述代码看出来,如果不使用链式调用的话,那么我们会增加很多重复的代码,而且特别冗余。而通过链式调用,我们可以节省很多代码,并且代码看起来更加优雅和整洁。那么,接下来,我们来讨论下如何实现一个支持链式调用的�库。

    了解过原型链的人都知道,由构造函数生成的实例都可以访问其原型对象的属性和方法,因此,我们让定义在原型对象的方法最后都返回this(调用该方法的实例),就可以对原型方法进行链式调用。

    通过立即执行函数,声明了一个_函数,并且将一个函数挂载到window上,并且每次调用()的时候,返回的其实是个_实例,由于原型对象方法里,执行最后都会返回一个this,因此就可以执行链式调用。

    (function () {
     // 构造函数
     function _$(selector) {
      // ...
     }
     
     _$.prototype = {
      addClass: function (className) {
       // ...
       return this;
      },
      removeClass: function (className) {
       // ...
       return this;
      },
      show: function () {
       // ...
       return this;
      }
     }; 
     _$.prototype.constructor = _$; 
     // 每次调用$()的时候,返回的其实是个_$实例
     window.$ = function () {
      return new _$(arguments);
     }
    })() 
    // 通过这种方式,我们就可以直接使用$的链式调用
    $(ele)//欢迎加入全栈开发交流圈一起学习交流:864305860
     .addClass('red')//面向1-3年前端人员
     .removeClass('green')//帮助突破技术瓶颈,提升思维能力
     .show();
    

    上述代码其实可以进行优化一下,因为假设你引入的库里,已经有人定义了$函数,�那么就会面临着命名冲突的问题。所以,我们可以为其增加一个安装器

    (function () {
     // 构造函数
     function _$(selector) {
      // ...
     } 
     _$.prototype = {
      addClass: function (className) {
       // ...
       return this;
      },
      removeClass: function (className) {
       // ...
       return this;
      },
      show: function () {
       // ...
       return this;
      }
     }; 
     _$.prototype.constructor = _$;
      // 增加一个安装器
     window.installHelper = function (scope, interface) {
      scope[interface] = function () {
       return new _$(arguments);
      }//欢迎加入全栈开发交流圈一起学习交流:864305860
     }//面向1-3年前端人员
    })(); //帮助突破技术瓶颈,提升思维能力
    // 而用户就可以这样使用它来自定义挂载对象以及其命名
    installHelper(window, '$'); 
    $(ele).show();
    

    有时候链式调用并不是一个好的主意。链式调用适用于赋值器方法,但是对于取值器方法的话,就不是很友好。因为我们有时候是想要方法返回一些数据,而不是返回一个this。对于这种情况的话,主要有两种解决方法,一种是对于取值器方法就不返回this,直接返回数据。而另一种方法呢,则是通过回调方法来处理数据:

    // 第一种方法,当遇到取值器,则直接返回数据
    (function () {
     // 构造函数
     function _$(selector) {
      this.ele = document.querySelector(selector);
      // ...
     }//欢迎加入全栈开发交流圈一起吹水聊天学习交流:864305860
      _$.prototype = {
      addClass: function (className) {
       // ...
       return this;
      },
      // 取值器
      getClass: function () {
       // ...
       return this.ele.className;
      }
     }; 
     _$.prototype.constructor = _$;
    })(); 
    // 第二种方式,通过回调的方式来处理数据
    (function () {
     // 构造函数
     function _$(selector) {
      this.ele = document.querySelector(selector);
      // ...
     } //欢迎加入全栈开发交流圈一起吹水聊天学习交流:864305860
     _$.prototype = {
      addClass: function (className) {
       // ...
       return this;
      },
      getClass: function (cb) {
       // ...
       cb.call(this, this.ele.className);
       return this;
      }//帮助突破技术瓶颈,提升思维能力
     }; //面向1-3年前端人员
     _$.prototype.constructor = _$;
    })();//欢迎加入全栈开发交流圈一起学习交流:864305860
    

    通过链式调用,我们可以简化我们的代码,让代码更加简洁易读。而我们只需要让类所有的方法都返回this值,就可以让该类变化一个支持方法链式调用的类。而如果要让取值器方法也支持链式调用,就可以在取值器里使用回调的方式来解决这个问题。

    结语

    感谢您的观看,如有不足之处,欢迎批评指正。

    本次给大家推荐一个免费的学习群,里面概括移动应用网站开发,css,html,webpack,vue node angular以及面试资源等。
    对web开发技术感兴趣的同学,欢迎加入Q群:864305860,不管你是小白还是大牛我都欢迎,还有大牛整理的一套高效率学习路线和教程与您免费分享,同时每天更新视频资料。
    最后,祝大家早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

    相关文章

      网友评论

        本文标题:详解Javasript设计模式之链式调用

        本文链接:https://www.haomeiwen.com/subject/gthtcqtx.html