javascript設(shè)計(jì)模式 – 迭代器模式原理與用法實(shí)例分析
本文實(shí)例講述了javascript設(shè)計(jì)模式 – 迭代器模式原理與用法。分享給大家供大家參考,具體如下:
介紹:迭代器模式是一種使用頻率非常高的設(shè)計(jì)模式,通過引入迭代器,可以將數(shù)據(jù)的遍歷功能從聚合對(duì)象中分離出來。迭代器模式用于順序訪問集合對(duì)象的元素,不需要知道集合對(duì)象的底層表示。
定義:提供一種方法來訪問聚合對(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ì)象的遍歷,通過游標(biāo)index來記錄聚合對(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)景:
* 訪問一個(gè)聚合對(duì)象的內(nèi)容而無須暴露它的內(nèi)部表示。
* 需要為一個(gè)聚合對(duì)象提供多種遍歷方式
* 為便利不同的聚合結(jié)構(gòu)提供一個(gè)統(tǒng)一的接口,為不同的聚合結(jié)構(gòu)實(shí)現(xiàn)不同的遍歷方式。
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
uniapp中使用?uni.navigateBack()?返回上級(jí)頁(yè)面并傳參的方法
最近遇到這樣的需求在A頁(yè)面中通過跳轉(zhuǎn)到B頁(yè)面,在B頁(yè)面中處理的數(shù)據(jù),需要跳轉(zhuǎn)回A頁(yè)面供其使用,本文給大家分享uniapp中使用?uni.navigateBack()?返回上級(jí)頁(yè)面并傳參的操作方法,感興趣的朋友一起看看吧2023-10-10
Bootstrap模態(tài)框(Modal)實(shí)現(xiàn)過渡效果
這篇文章主要為大家詳細(xì)介紹了Bootstrap模態(tài)框(Modal)實(shí)現(xiàn)過渡效果的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
網(wǎng)站導(dǎo)致瀏覽器崩潰的原因總結(jié)(多款瀏覽器) 推薦
對(duì)于訪客,如果登錄您網(wǎng)站,瀏覽器就立刻崩潰,我想這對(duì)誰(shuí)都是無法容忍的,對(duì)此總結(jié)了網(wǎng)站導(dǎo)致瀏覽器崩潰的原因2010-04-04
個(gè)人網(wǎng)站留言頁(yè)面(前端jQuery編寫、后臺(tái)php讀寫MySQL)
這篇文章主要為大家介紹了個(gè)人網(wǎng)站的留言頁(yè)面,前端使用jQuery編寫、后臺(tái)利用php簡(jiǎn)單讀寫MySQL數(shù)據(jù)庫(kù),感興趣的小伙伴們可以參考一下2016-05-05
對(duì)layui數(shù)據(jù)表格動(dòng)態(tài)cols(字段)動(dòng)態(tài)變化詳解
今天小編就為大家分享一篇對(duì)layui數(shù)據(jù)表格動(dòng)態(tài)cols(字段)動(dòng)態(tài)變化詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10
Three.js利用orbit controls插件(軌道控制)控制模型交互動(dòng)作詳解
這篇文章主要給大家介紹了關(guān)于Three.js利用orbit controls插件,也就是軌道控制來控制模型交互動(dòng)作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-09-09
JavaScript高級(jí)教程之如何玩轉(zhuǎn)箭頭函數(shù)
箭頭函數(shù)是在es6中添加的一種規(guī)范,箭頭函數(shù)相當(dāng)于匿名函數(shù),簡(jiǎn)化了函數(shù)的定義,下面這篇文章主要給大家介紹了關(guān)于JavaScript高級(jí)教程之如何玩轉(zhuǎn)箭頭函數(shù)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11

