亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JS中使用變量保存arguments對(duì)象的方法

 更新時(shí)間:2016年06月03日 11:56:52   作者:腳后跟著貓  
這篇文章主要介紹了JS中使用變量保存arguments對(duì)象的方法的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下

迭代器(iterator)是一個(gè)可以順序存取數(shù)據(jù)集合的對(duì)象。其一個(gè)典型的API是next方法。該方法獲得序列中的下一個(gè)值。

迭代器示例

題目:希望編寫一個(gè)便利的函數(shù),它可以接收任意數(shù)量的參數(shù),并為這些值建立一個(gè)迭代器。

測(cè)試代碼好下:

var it=values(,,,,,,,,);
it.next();//
it.next();//
it.next();// 

分析:由于values函數(shù)需要接收任意多個(gè)參數(shù),這里就需要用到上一節(jié)講到的構(gòu)建可變參數(shù)的函數(shù)的方法。然后里面的迭代器對(duì)象來(lái)遍歷arguments對(duì)象的元素。

初步編碼

function values(){
var i=,n=arguments.length;
return {
hasNext:function(){
return i<n;
},
next:function(){
if(this.hasNext()){
return arguments[i++];
}
throw new Error("已經(jīng)到達(dá)最后啦");
}
}
}

用上面的測(cè)試代碼進(jìn)行測(cè)試

var it=values(,,,,,,,,);
it.next();//undefined
it.next();//undefined
it.next();//undefined 

錯(cuò)誤分析

代碼運(yùn)行結(jié)果并不正確,下面就對(duì)初始的編碼程序進(jìn)行分析。

function values(){
var i=,n=arguments.length;//這里沒有錯(cuò)誤,arguments是values里的內(nèi)置對(duì)象
return {
hasNext:function(){
return i<n;
},
next:function(){
if(this.hasNext()){
return arguments[i++];//錯(cuò)誤出現(xiàn)在這里,arguments是next方法函數(shù)的內(nèi)置對(duì)象。
}
throw new Error("已經(jīng)到達(dá)最后啦");
}
}
} 

這里的指代錯(cuò)誤,很像是另一個(gè)讓人頭痛的對(duì)象this。處理this的指向時(shí),通常是使用變量和保存正確的this。然后在其它地方使用這個(gè)變量。那么arguments對(duì)象的解決方案就出來(lái)了,借助一個(gè)變量來(lái)存儲(chǔ),這樣arguments對(duì)象的指代就沒有問題了。

再次編碼

function values(){
var i=,n=arguments.length,arg=arguments;
return {
hasNext:function(){
return i<n;
},
next:function(){
if(this.hasNext()){
return arg[i++];
}
throw new Error("已經(jīng)到達(dá)最后啦");
}
}
} 

運(yùn)行測(cè)試代碼

var it=values(,,,,,,,,);
it.next();//
it.next();//
it.next();// 

結(jié)果和預(yù)期的相同。

提示

當(dāng)引用arguments時(shí)當(dāng)心函數(shù)嵌套層級(jí)

綁定一個(gè)明確作用域的引用到arguments變量,從而可以在嵌套的函數(shù)中引用它

附錄一:迭代器

迭代器(iterator)有時(shí)又稱游標(biāo)(cursor)是程序設(shè)計(jì)的軟件設(shè)計(jì)模式,可在容器上遍歷的接口,設(shè)計(jì)人員無(wú)需關(guān)心容器的內(nèi)容。

迭代器UML類圖


迭代器js實(shí)現(xiàn)

對(duì)設(shè)計(jì)模式了解一點(diǎn)點(diǎn),但具體項(xiàng)目中,有得多的也就是工廠模式,其它很少用,下面是一個(gè)簡(jiǎn)單的實(shí)現(xiàn),不對(duì)的地方,歡迎交流。

代碼如下

function List(){
this.data=[];
}
List.prototype={
add:function(){
var args=[].slice.call(arguments)
this.data=this.data.concat(args); 
},
remove:function(i){
this.data.splice(i,);
},
iterator:function(){
return new Iterator(this);
}
}
function Iterator(list){
this.list=list;
this.cur=;
};
Iterator.prototype={
hasNext:function(){
return this.cur<this.list.data.length-;
},
next:function(){
if(this.hasNext()){
return this.list.data[this.cur++];
}
throw new Error('已經(jīng)到底了~');
},
remove:function(){
this.list.remove(this.cur);
}
}
var list=new List();
var it=list.iterator();
list.add(,,,,,,,,);
it.next();//
it.next();//
it.next();// 

以上所述是小編給大家介紹的JS中使用變量保存arguments對(duì)象的方法,希望對(duì)大家有所幫助!

相關(guān)文章

  • 詳細(xì)聊聊TypeScript中unknown與any的區(qū)別

    詳細(xì)聊聊TypeScript中unknown與any的區(qū)別

    unknown類型比較謙虛,就和他本身的意思一樣,他從不禍害到其他的變量,但是any類型就是那種惡霸,屬于什么都不管,誰(shuí)也不敢管的類型,這篇文章主要給大家介紹了關(guān)于TypeScript中unknown與any區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2021-10-10
  • javascript實(shí)現(xiàn)帶節(jié)日和農(nóng)歷的日歷特效

    javascript實(shí)現(xiàn)帶節(jié)日和農(nóng)歷的日歷特效

    這篇文章主要介紹了javascript實(shí)現(xiàn)帶節(jié)日和農(nóng)歷的日歷特效,效果十分棒,需要的朋友可以參考下
    2015-02-02
  • 詳解javascript常用工具類的封裝

    詳解javascript常用工具類的封裝

    本篇文章主要給大家詳細(xì)分析了javascript常用工具類的封裝相關(guān)知識(shí)點(diǎn),有興趣的朋友參考下吧。
    2018-01-01
  • 微信小程序?qū)崿F(xiàn)藍(lán)牙打印

    微信小程序?qū)崿F(xiàn)藍(lán)牙打印

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)藍(lán)牙打印,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • javascript中活靈活現(xiàn)的Array對(duì)象詳解

    javascript中活靈活現(xiàn)的Array對(duì)象詳解

    本文的內(nèi)容就如同標(biāo)題一樣,這篇文章將會(huì)靈活的運(yùn)行Array對(duì)象的一些方法來(lái)實(shí)現(xiàn)看上去較復(fù)雜的應(yīng)用。相信對(duì)大家學(xué)習(xí)或者理解javascript中的Array對(duì)象能具有一定的參考借鑒價(jià)值,有需要的朋友們下面跟著小編一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。
    2016-11-11
  • 微信小程序?qū)崿F(xiàn)購(gòu)物車代碼實(shí)例詳解

    微信小程序?qū)崿F(xiàn)購(gòu)物車代碼實(shí)例詳解

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)購(gòu)物車代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • 3種js實(shí)現(xiàn)string的substring方法

    3種js實(shí)現(xiàn)string的substring方法

    這篇文章主要介紹了3種javascript實(shí)現(xiàn)string的substring方法,需要的朋友可以參考下
    2015-11-11
  • javascript實(shí)現(xiàn)電腦和手機(jī)版樣式切換

    javascript實(shí)現(xiàn)電腦和手機(jī)版樣式切換

    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)電腦和手機(jī)版樣式切換,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 全面解析JavaScript中的valueOf與toString方法(推薦)

    全面解析JavaScript中的valueOf與toString方法(推薦)

    本文給大家介紹JavaScript中的valueOf與toString方法,valueOf() 方法可返回 Boolean 對(duì)象的原始值,toString() 方法可把一個(gè)邏輯值轉(zhuǎn)換為字符串,并返回結(jié)果。對(duì)js中valueof和tostring相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2016-06-06
  • javascript移動(dòng)設(shè)備Web開發(fā)中對(duì)touch事件的封裝實(shí)例

    javascript移動(dòng)設(shè)備Web開發(fā)中對(duì)touch事件的封裝實(shí)例

    這篇文章主要介紹了javascript移動(dòng)設(shè)備Web開發(fā)中對(duì)touch事件的封裝實(shí)例,分別對(duì)tap事件、doubleTap事件、longTap事件、swipe事件做了封裝,需要的朋友可以參考下
    2014-06-06

最新評(píng)論