亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

Javasript設計模式之鏈式調用詳解

2024-05-06 16:43:57
字體:
來源:轉載
供稿:網友

本文實例為大家分享了js設計模式之鏈式調用的具體代碼,供大家參考,具體內容如下

寫過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值,就可以讓該類變化一個支持方法鏈式調用的類。而如果要讓取值器方法也支持鏈式調用,就可以在取值器里使用回調的方式來解決這個問題。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品中文在线| 国产精品流白浆视频| 午夜精品久久久久久久99热浪潮| 国产精品久久久久久久久免费| 在线电影欧美日韩一区二区私密| 欧美国产在线电影| 最新69国产成人精品视频免费| 国产一区二区色| 亚洲国产精品久久久久秋霞不卡| 亚洲一区二区三区久久| 欧美精品久久久久久久久久| 亚洲国产成人在线播放| 久久综合电影一区| 538国产精品视频一区二区| 欧美日韩在线另类| 久久乐国产精品| 欧美在线日韩在线| 久久精品色欧美aⅴ一区二区| 97激碰免费视频| 91九色在线视频| 久久久久久亚洲| 97香蕉超级碰碰久久免费软件| 伊人久久久久久久久久久| 亚洲美女激情视频| 国产精品ⅴa在线观看h| 欧美区在线播放| 国产+人+亚洲| 国产精品久久久久77777| 在线亚洲男人天堂| 欧美视频国产精品| www欧美xxxx| 亚洲欧美综合区自拍另类| 国产精品大片wwwwww| 国产噜噜噜噜久久久久久久久| 亚洲欧洲在线免费| 性欧美xxxx视频在线观看| 亚洲аv电影天堂网| 久久久国产精品x99av| 国产精品中文久久久久久久| 亚洲天堂开心观看| 免费97视频在线精品国自产拍| 国产亚洲欧美视频| 福利精品视频在线| 久久人人爽人人| 国产91精品视频在线观看| 欧美国产极速在线| 浅井舞香一区二区| 国产精品夜间视频香蕉| 中文字幕少妇一区二区三区| 亚洲高清免费观看高清完整版| 日韩美女在线看| 欧美日本高清一区| 午夜精品久久久久久99热| 国产美女被下药99| 国产精品九九九| 国产精品久久久久av免费| 精品一区二区三区三区| 91在线观看免费高清| 欧美亚洲第一页| 一本一本久久a久久精品牛牛影视| 影音先锋日韩有码| 播播国产欧美激情| 国模视频一区二区| 久久在线免费视频| 55夜色66夜色国产精品视频| 91精品国产综合久久香蕉| 国产福利视频一区| 亚洲国产成人精品电影| 国产69精品久久久| 亚洲欧美日韩爽爽影院| 亚洲一区二区久久久久久| 91麻豆国产语对白在线观看| 91在线中文字幕| 久久精品影视伊人网| 亚洲精品短视频| 国产欧美在线观看| 96精品久久久久中文字幕| 欧美久久久精品| 国产精品高潮视频| 日本韩国在线不卡| 亚洲自拍小视频免费观看| 国产精品久久久亚洲| 国产在线精品一区免费香蕉| 亚洲mm色国产网站| 国产91色在线免费| 97视频网站入口| 国产欧美日韩亚洲精品| 欧美成年人视频网站欧美| 国产精品美腿一区在线看| 国产日韩在线视频| 国产激情视频一区| 国产精品最新在线观看| 国产三级精品网站| 美女久久久久久久久久久| 亚洲天堂av在线免费| 欧美激情乱人伦一区| 色婷婷久久一区二区| 久久久久久久91| 亚洲精品美女久久久久| 亚洲成人动漫在线播放| 久久亚洲精品成人| 国产精品视频午夜| 欧美片一区二区三区| 亚洲精品久久久久久久久久久| 北条麻妃一区二区在线观看| 亚洲欧美一区二区三区久久| 国产精品一区二区av影院萌芽| 久久久久久国产精品| 国产精品亚洲一区二区三区| 国内精品久久久久久久久| 97人人爽人人喊人人模波多| 欧美精品国产精品日韩精品| 永久免费毛片在线播放不卡| 日韩av黄色在线观看| 欧美韩日一区二区| 久久手机免费视频| 久久精品久久久久电影| 欧美一级高清免费| 欧美电影在线观看高清| 国产精品久久久久久搜索| 亚洲视频在线视频| 国产精品99久久久久久人| 欧美成人午夜激情| 欧美黄色片在线观看| 成人久久18免费网站图片| 日本国产一区二区三区| 亚洲欧美变态国产另类| 91久久嫩草影院一区二区| 久久电影一区二区| 亚洲欧美国产va在线影院| 日韩中文字幕免费| 欧美日韩国产综合视频在线观看中文| 久久久精品网站| 性夜试看影院91社区| 国产亚洲精品91在线| 伊人久久久久久久久久久久久| 97精品国产91久久久久久| 亚洲午夜女主播在线直播| 欧美最猛性xxxxx亚洲精品| 伊人男人综合视频网| 国产69精品久久久| 97视频网站入口| 欧美在线视频一区二区| 欧美成人免费大片| 久久频这里精品99香蕉| 91性高湖久久久久久久久_久久99| 欧美成aaa人片免费看| 欧美在线视频免费播放| 欧美香蕉大胸在线视频观看| 久久这里有精品视频| 夜夜嗨av色综合久久久综合网| 一本色道久久88综合日韩精品| 国产一区二区三区毛片| 亚洲欧美日本精品| 91影院在线免费观看视频| 亚洲午夜未删减在线观看| 久久精品亚洲94久久精品| 亚洲欧美一区二区三区久久| 91精品久久久久久久久青青| 国产成人在线亚洲欧美| 在线播放日韩精品| 国产精品96久久久久久又黄又硬| 最新国产成人av网站网址麻豆| 欧美老女人性视频|