婷婷久久综合九色综合,欧美成色婷婷在线观看视频,偷窥视频一区,欧美日本一道道一区二区

<tt id="bu9ss"></tt>
  • <span id="bu9ss"></span>
  • <pre id="bu9ss"><tt id="bu9ss"></tt></pre>
    <label id="bu9ss"></label>

    當(dāng)前位置:首頁 >  站長(zhǎng) >  編程技術(shù) >  正文

    for……in for……of 區(qū)別

     2020-11-17 13:39  來源: 田珊珊個(gè)人博客   我來投稿 撤稿糾錯(cuò)

      阿里云優(yōu)惠券 先領(lǐng)券再下單

    1 遍歷數(shù)組通常用for循環(huán)

    ES5的話也可以使用forEach,ES5具有遍歷數(shù)組功能的還有map、filter、some、every、reduce、reduceRight等,只不過他們的返回結(jié)果不一樣。但是使用foreach遍歷數(shù)組的話,使用break不能中斷循環(huán),使用return也不能返回到外層函數(shù)。

    Array.prototype.method=function(){

    console.log(this.length);

    }

    var myArray=[1,2,4,5,6,7]

    myArray.name="數(shù)組"

    for (var index in myArray) {

    console.log(myArray[index]);

    }

    2 for in遍歷數(shù)組的毛病

    1.index索引為字符串型數(shù)字,不能直接進(jìn)行幾何運(yùn)算

    2.遍歷順序有可能不是按照實(shí)際數(shù)組的內(nèi)部順序

    3.使用for in會(huì)遍歷數(shù)組所有的可枚舉屬性,包括原型。例如上栗的原型方法method和name屬性

    所以for in更適合遍歷對(duì)象,不要使用for in遍歷數(shù)組。

    那么除了使用for循環(huán),如何更簡(jiǎn)單的正確的遍歷數(shù)組達(dá)到我們的期望呢(即不遍歷method和name),ES6中的for of更勝一籌.

    Array.prototype.method=function(){

    console.log(this.length);

    }

    var myArray=[1,2,4,5,6,7]

    myArray.name="數(shù)組";

    for (var value of myArray) {

    console.log(value);

    }

    for in遍歷的是數(shù)組的索引(即鍵名),而for of遍歷的是數(shù)組元素值。

    for of遍歷的只是數(shù)組內(nèi)的元素,而不包括數(shù)組的原型屬性method和索引name

    3 遍歷對(duì)象

    遍歷對(duì)象 通常用for in來遍歷對(duì)象的鍵名

    Object.prototype.method=function(){

    console.log(this);

    }

    var myObject={

    a:1,

    b:2,

    c:3

    }

    for (var key in myObject) {

    console.log(key);

    }

    for in 可以遍歷到myObject的原型方法method,如果不想遍歷原型方法和屬性的話,可以在循環(huán)內(nèi)部判斷一下,hasOwnPropery方法可以判斷某屬性是否是該對(duì)象的實(shí)例屬性

    for (var key in myObject) {

    if(myObject.hasOwnProperty(key)){

    console.log(key);

    }

    }

    同樣可以通過ES5的Object.keys(myObject)獲取對(duì)象的實(shí)例屬性組成的數(shù)組,不包括原型方法和屬性

    Object.prototype.method=function(){

    console.log(this);

    }

    var myObject={

    a:1,

    b:2,

    c:3

    }

    for..of適用遍歷數(shù)/數(shù)組對(duì)象/字符串/map/set等擁有迭代器對(duì)象的集合.但是不能遍歷對(duì)象,因?yàn)闆]有迭代器對(duì)象.與forEach()不同的是,它可以正確響應(yīng)break、continue和return語句

    for-of循環(huán)不支持普通對(duì)象,但如果你想迭代一個(gè)對(duì)象的屬性,你可以用for-in循環(huán)(這也是它的本職工作)或內(nèi)建的Object.keys()方法:

    for (var key of Object.keys(someObject)) {

    console.log(key + ": " + someObject[key]);

    }

    遍歷map對(duì)象時(shí)適合用解構(gòu),例如;

    for (var [key, value] of phoneBookMap) {

    console.log(key + "'s phone number is: " + value);

    }

    附:跳出循環(huán)

    foreach 不能終止或跳過循環(huán)

    for of 支持跳出循環(huán)

    const fruits = ['Apple','Banana','Orange','Mango'];

    for(let fruit of fruits){

    if(fruit === 'Orange'){

    break;  //終止

    }

    console.log(fruit);  // Apple Banana

    }

    for(let fruit of fruits){

    if(fruit === 'Orange'){

    continue;  //跳出循環(huán)

    }

    console.log(fruit);  // Apple Banana Mango

    }

    文章來源:田珊珊個(gè)人博客

    來源地址:http://www.tianshan277.com/756.html

    申請(qǐng)創(chuàng)業(yè)報(bào)道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!

    相關(guān)文章

    熱門排行

    信息推薦