写过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).addClass('red').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);}}
})();// 而用户就可以这样使用它来自定义挂载对象以及其命名
installHelper(window, '$');$(ele).show();

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

// 第一种方法,当遇到取值器,则直接返回数据
(function () {// 构造函数function _$(selector) {this.ele = document.querySelector(selector);// ...}_$.prototype = {addClass: function (className) {// ...return this;},// 取值器getClass: function () {// ...return this.ele.className;}};_$.prototype.constructor = _$;
})();// 第二种方式,通过回调的方式来处理数据
(function () {// 构造函数function _$(selector) {this.ele = document.querySelector(selector);// ...}_$.prototype = {addClass: function (className) {// ...return this;},getClass: function (cb) {// ...cb.call(this, this.ele.className);return this;}};_$.prototype.constructor = _$;
})();

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

转载于:https://www.cnblogs.com/chenjg/p/8904067.html

Javasript设计模式之链式调用相关推荐

  1. Javascript基础知识篇(5): 面向对象之链式调用

    在我们平常的web开发中,已经存在各种大型的专业Javascript类库(JQuery,Prototype,ExtJS)等,它们都充分利用了Javascript面向对象的思想,使得类库更加富有灵活性和 ...

  2. spring aop 之链式调用

    关关雎鸠,在河之洲.窈窕淑女,君子好逑. 概述 AOP(Aspect Orient Programming),我们一般称为面向方面(切面)编程,作为面向对象的一种补充,用于处理系统中分布于各个模块的横 ...

  3. 设计模式之建造者模式(含链式调用)

    开始之前 大家都知道建造者模式是23种设计模式之一,其属于创建型模式,我们可以先看一下菜鸟教程对建造者模式的介绍. 建造者模式(Builder Pattern)使用多个简单的对象一步一步构建成一个复杂 ...

  4. BC之链式块状结构:区块链之链式块状结构——链式块状结构、内容相关配图

    BC之链式块状结构:区块链之链式块状结构--链式块状结构.内容相关配图 目录 区块链之链式块状结构.内容相关配图 1.区块链结构 区块链之链式块状结构.内容相关配图 1.区块链结构

  5. 阐述Linux动态库的显式调用

    阐述Linux动态库的显式调用 分类: Linux 2011-02-12 10:27 168人阅读 评论(0) 收藏 举报 linux测试nulllibrarypathgcc 十年的发展,Linux系 ...

  6. linux下动态链接库(.so)的显式调用和隐式调用

    进入主题前,先看看两点预备知识. 一.显式调用和隐式调用的区别 我们知道,动态库相比静态库的区别是:静态库是编译时就加载到可执行文件中的,而动态库是在程序运行时完成加载的,所以使用动态库的程序的体积要 ...

  7. QT显式调用VC开发的DLL

    首先用visual studio创建dll. 然后通过QLibrary显式调用dll #include "QLibrary"

  8. QT隐式调用VC开发的DLL

    首先用vs开发一个简单的dll 头文件testdll.h #include <Windows.h> extern "C" int WINAPI Add(int x, i ...

  9. 数据结构-队列之链式队列

    队列的链式表示称为链队列,它实际上是一个同时带有队头指针和队尾指针的单链表.头指针指向队头节点,尾指针指向队尾节点,即单链表的最后一个节点. 当q.front==NULL且q.rear==NULL时, ...

最新文章

  1. AFN 切换BaseUrl
  2. CoreOS 和 Kubernetes 1.5 自主运行 Kubernetes、Container Linux
  3. 苹果成AI“收购狂魔”,5年买下25家公司
  4. 用c语言简单办法做一个字典_幼儿园手工,用废纸筒做一个简单的小蝴蝶,有教程...
  5. 美剧 《圣经故事》 故事线
  6. 创建控制文件后的疑难解答
  7. wpf 自动完成comboxBox
  8. python shelve模块_python中的Shelve模块不工作:“无法确定db type”
  9. Linux fcntl函数详解
  10. 二进制、十进制、十六进制数值对照表
  11. tuio+ 图片拼接软件制作方法
  12. 照片拼图软件:Picture Collage Maker for Mac
  13. 用python写一个PDF翻译软件
  14. 什么蓝牙耳机好?测评达人精选五款性价比高蓝牙耳机推荐
  15. 做强信息产业 拓宽智慧城市发展路径
  16. 实战之jvm-sandbox动态加载插件实现
  17. 什么是图灵机及图灵完备(一)
  18. java 硬件中断_Java异步事件:轮询与中断
  19. 某Keylogger分析
  20. matlab单根检验,关于单位根检验输出结果问题?

热门文章

  1. Android开发:《Gradle Recipes for Android》阅读笔记1.3
  2. 期货黄金与现货黄金比较
  3. 敏捷项目开源管理软件ScrumBasic(2)- 多项目支持
  4. uva10617 - Again Palindrome(dp)
  5. C#中往数据库插入/更新时候关于NUll空值的处理
  6. 黑马程序员——生成html静态页面,方便seo,加快加载速度
  7. 深入理解CSS盒模型 - 程序猿的程 - 博客园
  8. javascript --- 函数的优化(尾调用优化)
  9. Vite+Vue3页面空白、图标不显示问题解决
  10. ES5-4 函数基础与种类、形实参及映射、变量类型