這篇文章將為大家詳細(xì)講解有關(guān)ES6中迭代器與生成器的示例分析,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:空間域名、虛擬空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、阿克塞哈薩克族自治網(wǎng)站維護(hù)、網(wǎng)站推廣。具體如下:
循環(huán)語(yǔ)句的問題
var colors = ["red", "green", "blue"]; for(var i=0; i在ES6之前,這種標(biāo)準(zhǔn)的for循環(huán),通過變量來跟蹤數(shù)組的索引。如果多個(gè)循環(huán)嵌套就需要追蹤多個(gè)變量,代碼復(fù)雜度會(huì)大大增加,也容易產(chǎn)生錯(cuò)用循環(huán)變量的bug。
迭代器的出現(xiàn)旨在消除這種復(fù)雜性并減少循環(huán)中的錯(cuò)誤。
什么是迭代器
我們先感受一下用ES5語(yǔ)法模擬創(chuàng)建一個(gè)迭代器:
function createIterator(items) { var i = 0; return { // 返回一個(gè)迭代器對(duì)象 next: function() { // 迭代器對(duì)象一定有個(gè)next()方法 var done = (i >= items.length); var value = !done ? items[i++] : undefined; return { // next()方法返回結(jié)果對(duì)象 value: value, done: done }; } }; } var iterator = createIterator([1, 2, 3]); console.log(iterator.next()); // "{ value: 1, done: false}" console.log(iterator.next()); // "{ value: 2, done: false}" console.log(iterator.next()); // "{ value: 3, done: false}" console.log(iterator.next()); // "{ value: undefiend, done: true}" // 之后所有的調(diào)用都會(huì)返回相同內(nèi)容 console.log(iterator.next()); // "{ value: undefiend, done: true}"以上,我們通過調(diào)用createIterator()函數(shù),返回一個(gè)對(duì)象,這個(gè)對(duì)象存在一個(gè)next()方法,當(dāng)next()方法被調(diào)用時(shí),返回格式{ value: 1, done: false}的結(jié)果對(duì)象。
因此,我們可以這么定義:迭代器是一個(gè)擁有next()方法的特殊對(duì)象,每次調(diào)用next()都返回一個(gè)結(jié)果對(duì)象。
借助這個(gè)迭代器對(duì)象,我們來改造剛開始那個(gè)標(biāo)準(zhǔn)的for循環(huán)【暫時(shí)先忘記ES6的for-of循環(huán)新特性】:
var colors = ["red", "green", "blue"]; var iterator = createIterator(colors); while(!iterator.next().done){ console.log(iterator.next().value); }what?,消除循環(huán)變量而已,需要搞這么麻煩,代碼上不是得不償失了嗎?
并非如此,畢竟createIterator()只需寫一次,就可以一直復(fù)用。不過ES6引入了生成器對(duì)象,可以讓創(chuàng)建迭代器的過程變得更加簡(jiǎn)單。
什么是生成器
生成器是一種返回迭代器的函數(shù),通過function關(guān)鍵字后的星號(hào)(*)來表示,函數(shù)中會(huì)用到新的關(guān)鍵字yield。
function *createIterator(items) { for(let i=0; i上面,我們用ES6的生成,大大簡(jiǎn)化了迭代器的創(chuàng)建過程。我們給生成器函數(shù)createIterator()傳入一個(gè)items數(shù)組,函數(shù)內(nèi)部,for循環(huán)不斷從數(shù)組中生成新的元素放入迭代器中,每遇到一個(gè)yield語(yǔ)句循環(huán)都會(huì)停止;每次調(diào)用迭代器的next()方法,循環(huán)便繼續(xù)運(yùn)行并停止在下一條yield語(yǔ)句處。
生成器的創(chuàng)建方式
生成器是個(gè)函數(shù):
function *createIterator(items) { ... }可以用函數(shù)表達(dá)式方式書寫:
let createIterator = function *(item) { ... }也可以添加到對(duì)象中,ES5風(fēng)格對(duì)象字面量:
let o = { createIterator: function *(items) { ... } }; let iterator = o.createIterator([1, 2, 3]);ES6風(fēng)格的對(duì)象方法簡(jiǎn)寫方式:
let o = { *createIterator(items) { ... } }; let iterator = o.createIterator([1, 2, 3]);可迭代對(duì)象
在ES6中,所有的集合對(duì)象(數(shù)組、Set集合及Map集合)和字符串都是可迭代對(duì)象,可迭代對(duì)象都綁定了默認(rèn)的迭代器。
來了來了,姍姍來遲的ES6循環(huán)新特性for-of:
var colors = ["red", "green", "blue"]; for(let color of colors){ console.log(color); }for-of循環(huán),可作用在可迭代對(duì)象上,正是利用了可迭代對(duì)象上的默認(rèn)迭代器。大致過程是:for-of循環(huán)每執(zhí)行一次都會(huì)調(diào)用可迭代對(duì)象的next()方法,并將迭代器返回的結(jié)果對(duì)象的value屬性存儲(chǔ)在變量中,循環(huán)將繼續(xù)執(zhí)行這一過程直到返回對(duì)象的done屬性的值為true。
如果只需要迭代數(shù)組或集合中的值,用for-of循環(huán)代替for循環(huán)是個(gè)不錯(cuò)的選擇。
訪問默認(rèn)迭代器
可迭代對(duì)象,都有一個(gè)Symbol.iterator方法,for-of循環(huán)時(shí),通過調(diào)用colors數(shù)組的Symbol.iterator方法來獲取默認(rèn)迭代器的,這一過程是在JavaScript引擎背后完成的。
我們可以主動(dòng)獲取一下這個(gè)默認(rèn)迭代器來感受一下:
let values = [1, 2, 3]; let iterator = values[Symbol.iterator](); console.log(iterator.next()); // "{ value: 1, done: false}" console.log(iterator.next()); // "{ value: 2, done: false}" console.log(iterator.next()); // "{ value: 3, done: false}" console.log(iterator.next()); // "{ value: undefined, done: true}"在這段代碼中,通過Symbol.iterator獲取了數(shù)組values的默認(rèn)迭代器,并用它遍歷數(shù)組中的元素。在JavaScript引擎中執(zhí)行for-of循環(huán)語(yǔ)句也是類似的處理過程。
用Symbol.iterator屬性來檢測(cè)對(duì)象是否為可迭代對(duì)象:
function isIterator(object) { return typeof object[Symbol.iterator] === "function"; } console.log(isIterable([1, 2, 3])); // true console.log(isIterable(new Set())); // true console.log(isIterable(new Map())); // true console.log(isIterable("Hello")); // true創(chuàng)建可迭代對(duì)象
當(dāng)我們?cè)趧?chuàng)建對(duì)象時(shí),給Symbol.iterator屬性添加一個(gè)生成器,則可以將其變成可迭代對(duì)象:
let collection = { items: [], *[Symbol.iterator]() { // 將生成器賦值給對(duì)象的Symbol.iterator屬性來創(chuàng)建默認(rèn)的迭代器 for(let item of this.items) { yield item; } } }; collection.items.push(1); collection.items.push(2); collection.items.push(3); for(let x of collection) { console.log(x); }內(nèi)建迭代器
ES6中的集合對(duì)象,數(shù)組、Set集合和Map集合,都內(nèi)建了三種迭代器:
entries() 返回一個(gè)迭代器,其值為多個(gè)鍵值對(duì)。如果是數(shù)組,第一個(gè)元素是索引位置;如果是Set集合,第一個(gè)元素與第二個(gè)元素一樣,都是值。
values() 返回一個(gè)迭代器,其值為集合的值。
keys() 返回一個(gè)迭代器,其值為集合中的所有鍵名。如果是數(shù)組,返回的是索引;如果是Set集合,返回的是值(Set的值被同時(shí)用作鍵和值)。
不同集合的默認(rèn)迭代器
每個(gè)集合類型都有一個(gè)默認(rèn)的迭代器,在for-of循環(huán)中,如果沒有顯式指定則使用默認(rèn)的迭代器。按常規(guī)使用習(xí)慣,我們很容易猜到,數(shù)組和Set集合的默認(rèn)迭代器是values(),Map集合的默認(rèn)迭代器是entries()。
請(qǐng)看以下示例:
let colors = [ "red", "green", "blue"]; let tracking = new Set([1234, 5678, 9012]); let data = new Map(); data.set("title", "Understanding ECMAScript 6"); data.set("format", "print"); // 與調(diào)用colors.values()方法相同 for(let value of colors) { console.log(value); } // 與調(diào)用tracking.values()方法相同 for(let num of tracking) { console.log(num); } // 與調(diào)用data.entries()方法相同 for(let entry of data) { console.log(entry); }這段代碼會(huì)輸入以下內(nèi)容:
"red"
"green"
"blue"
1234
5678
9012
["title", "Understanding ECMAScript 6"]
["format", "print"]for-of循環(huán)配合解構(gòu)特性,操縱數(shù)據(jù)會(huì)更方便:
for(let [key, value] of data) { console.log(key + "=" + value); }展開運(yùn)算符操縱可迭代對(duì)象
let set = new Set([1, 2, 3, 4, 5]), array = [...set]; console.log(array); // [1,2,3,4,5]展開運(yùn)算符可以操作所有的可迭代對(duì)象,并根據(jù)默認(rèn)迭代器來選取要引用的值,從迭代器讀取所有值。然后按返回順序?qū)⑺鼈円来尾迦氲綌?shù)組中。因此如果想將可迭代對(duì)象轉(zhuǎn)換為數(shù)組,用展開運(yùn)算符是最簡(jiǎn)單的方法。
關(guān)于“ES6中迭代器與生成器的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
文章題目:ES6中迭代器與生成器的示例分析-創(chuàng)新互聯(lián)
URL標(biāo)題:http://weahome.cn/article/ddshce.html