溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Javasript設(shè)計模式之鏈式調(diào)用的示例分析

發(fā)布時間:2021-06-26 10:20:00 來源:億速云 閱讀:150 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細講解有關(guān)Javasript設(shè)計模式之鏈式調(diào)用的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

具體內(nèi)容如下

寫過jquery的可能都知道,jquery里面可以很方便的使用以下代碼:

// 不使用鏈式調(diào)用
const element = $(ele);
element.addClass('red');
element.removeClass('green');
element.show();

// 鏈式調(diào)用
$(ele)
 .addClass('red')
 .removeClass('green')
 .show();

而jquery這種調(diào)用方式就是鏈式調(diào)用。我們可以從上述代碼看出來,如果不使用鏈式調(diào)用的話,那么我們會增加很多重復(fù)的代碼,而且特別冗余。而通過鏈式調(diào)用,我們可以節(jié)省很多代碼,并且代碼看起來更加優(yōu)雅和整潔。那么,接下來,我們來討論下如何實現(xiàn)一個支持鏈式調(diào)用的庫。

了解過原型鏈的人都知道,由構(gòu)造函數(shù)生成的實例都可以訪問其原型對象的屬性和方法,因此,我們讓定義在原型對象的方法最后都返回this(調(diào)用該方法的實例),就可以對原型方法進行鏈式調(diào)用。

// 通過立即執(zhí)行函數(shù),聲明了一個_$函數(shù),并且將一個$函數(shù)掛載到window上,并且每次調(diào)用$()的時候,返回的其實是個_$實例,由于原型對象方法里,執(zhí)行最后都會返回一個this,因此就可以執(zhí)行鏈式調(diào)用。
(function () {
 // 構(gòu)造函數(shù)
 function _$(selector) {
  // ...
 }

 _$.prototype = {
  addClass: function (className) {
   // ...
   return this;
  },
  removeClass: function (className) {
   // ...
   return this;
  },
  show: function () {
   // ...
   return this;
  }
 };

 _$.prototype.constructor = _$;

 // 每次調(diào)用$()的時候,返回的其實是個_$實例
 window.$ = function () {
  return new _$(arguments);
 }
})();

// 通過這種方式,我們就可以直接使用$的鏈式調(diào)用
$(ele)
 .addClass('red')
 .removeClass('green')
 .show();

當然,上述代碼其實可以進行優(yōu)化一下,因為假設(shè)你引入的庫里,已經(jīng)有人定義了$函數(shù),那么就會面臨著命名沖突的問題。所以,我們可以為其增加一個安裝器

(function () {
 // 構(gòu)造函數(shù)
 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();

當然,有時候鏈式調(diào)用并不是一個好的主意。鏈式調(diào)用適用于賦值器方法,但是對于取值器方法的話,就不是很友好。因為我們有時候是想要方法返回一些數(shù)據(jù),而不是返回一個this。對于這種情況的話,主要有兩種解決方法,一種是對于取值器方法就不返回this,直接返回數(shù)據(jù)。而另一種方法呢,則是通過回調(diào)方法來處理數(shù)據(jù):

// 第一種方法,當遇到取值器,則直接返回數(shù)據(jù)
(function () {
 // 構(gòu)造函數(shù)
 function _$(selector) {
  this.ele = document.querySelector(selector);
  // ...
 }

 _$.prototype = {
  addClass: function (className) {
   // ...
   return this;
  },
  // 取值器
  getClass: function () {
   // ...
   return this.ele.className;
  }
 };

 _$.prototype.constructor = _$;
})();

// 第二種方式,通過回調(diào)的方式來處理數(shù)據(jù)
(function () {
 // 構(gòu)造函數(shù)
 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 = _$;
})();

關(guān)于“Javasript設(shè)計模式之鏈式調(diào)用的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI