您好,登錄后才能下訂單哦!
這篇文章主要講解了如何使用javascript中的迭代器模式,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。
介紹:迭代器模式是一種使用頻率非常高的設(shè)計(jì)模式,通過(guò)引入迭代器,可以將數(shù)據(jù)的遍歷功能從聚合對(duì)象中分離出來(lái)。迭代器模式用于順序訪問(wèn)集合對(duì)象的元素,不需要知道集合對(duì)象的底層表示。
定義:提供一種方法來(lái)訪問(wèn)聚合對(duì)象,而不用暴露這個(gè)對(duì)象的內(nèi)部表示,其別名為游標(biāo)(Cursor)。迭代器模式是一種對(duì)象行為型模式。
場(chǎng)景:我們做一個(gè)百家姓的迭代器
示例:
function NameRepository(){ var names = ['趙','錢','孫','李']; this.getIterator = function(){ return new NameIterator(); } function NameIterator(){ var index = 0; //判斷是否存在下一個(gè)元素 this.hasNext = function(){ return index < names.length; } //將游標(biāo)指向第一個(gè)元素 this.first = function(){ index = 0; } //獲取游標(biāo)指向的當(dāng)前元素 this.currentItem = function(){ return names[index]; } this.next = function(){ if(this.hasNext()){ return names[index++] } return null; } } } var nameRepository = new NameRepository(); for(var iter = nameRepository.getIterator(); iter.hasNext();){ console.log(iter.next()) } // 趙 // 錢 // 孫 // 李
例子中NameIterator稱為具體迭代器,它實(shí)現(xiàn)了對(duì)聚合對(duì)象的遍歷,通過(guò)游標(biāo)index來(lái)記錄聚合對(duì)象當(dāng)前位置,游標(biāo)通常為一個(gè)表示位置的非負(fù)整數(shù)。
需要注意的是迭代器的接口設(shè)計(jì)非常重要,一方面要充分滿足各種遍歷操作的要求,另一方面又不能包含太多方法。
迭代器模式總結(jié):
優(yōu)點(diǎn):
* 支持以不同的方式遍歷一個(gè)聚合對(duì)象,在同一個(gè)聚合對(duì)象上可以定義多種遍歷方式
* 迭代器簡(jiǎn)化了聚合類,原有的聚合對(duì)象不需要自行提供數(shù)據(jù)遍歷方法。
缺點(diǎn):
* 迭代器模式將存儲(chǔ)數(shù)據(jù)和遍歷數(shù)據(jù)的職責(zé)分離,一定程度增加了系統(tǒng)的復(fù)雜性
* 迭代器設(shè)計(jì)難度較大,需要充分考慮可擴(kuò)展性。
適用場(chǎng)景:
* 訪問(wèn)一個(gè)聚合對(duì)象的內(nèi)容而無(wú)須暴露它的內(nèi)部表示。
* 需要為一個(gè)聚合對(duì)象提供多種遍歷方式
* 為便利不同的聚合結(jié)構(gòu)提供一個(gè)統(tǒng)一的接口,為不同的聚合結(jié)構(gòu)實(shí)現(xiàn)不同的遍歷方式。
看完上述內(nèi)容,是不是對(duì)如何使用javascript中的迭代器模式有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。