在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美

當(dāng)前位置:雨林木風(fēng)下載站 > 網(wǎng)頁設(shè)計(jì)教程 > 詳細(xì)頁面

JavaScript中 for、for in、for of、forEach的用法小結(jié)(附代碼)

JavaScript中 for、for in、for of、forEach的用法小結(jié)(附代碼)

更新時(shí)間:2025-12-08 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

導(dǎo)網(wǎng)頁的本質(zhì)就是超級(jí)文本標(biāo)記語言,通過結(jié)合使用其他的Web技術(shù)(如:腳本語言、公共網(wǎng)關(guān)接口、組件等),可以創(chuàng)造出功能強(qiáng)大的網(wǎng)頁。因而,超級(jí)文本標(biāo)記語言是萬維網(wǎng)(Web)編程的基礎(chǔ),也就是說萬維網(wǎng)是建立...
網(wǎng)頁的本質(zhì)就是超級(jí)文本標(biāo)記語言,通過結(jié)合使用其他的Web技術(shù)(如:腳本語言、公共網(wǎng)關(guān)接口、組件等),可以創(chuàng)造出功能強(qiáng)大的網(wǎng)頁。因而,超級(jí)文本標(biāo)記語言是萬維網(wǎng)(Web)編程的基礎(chǔ),也就是說萬維網(wǎng)是建立在超文本基礎(chǔ)之上的。超級(jí)文本標(biāo)記語言之所以稱為超文本標(biāo)記語言,是因?yàn)槲谋局邪怂^“超級(jí)鏈接”點(diǎn)。
本篇文章給大家?guī)淼膬?nèi)容是關(guān)于JavaScript中 for、for in、for of、forEach的用法小結(jié)(附代碼),有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對你有所幫助。

在JavaScript中,我們經(jīng)常需要去循環(huán)迭代方法操作數(shù)組對象等,常見等循環(huán)方法有 for、for in、for of、forEach等。

1.for循環(huán)

for循環(huán)是最基礎(chǔ)常見的一種循環(huán),圓括號(hào)中需要三個(gè)表達(dá)式,由分號(hào)分隔,最后面是一個(gè)花括號(hào)的塊語句。

for (var i = 0; i <10; i++){
    if (i === 5) {
        continue; //跳出當(dāng)前循環(huán)
    } else if (i === 8) {
        break;    //結(jié)束循環(huán)
    }
    console.log(i);
}

for循環(huán)中的語句

continue 語句用來跳出本次循環(huán),但會(huì)繼續(xù)執(zhí)行后面的循環(huán)。
break 語句用來結(jié)束循環(huán),后面的循環(huán)不會(huì)再執(zhí)行。
return 并不能用來跳出for循環(huán),return語句只能出現(xiàn)在函數(shù)體內(nèi),它會(huì)終止函數(shù)的執(zhí)行,并返回一個(gè)指定的值。

使用for循環(huán)中遇到的問題

你可能會(huì)遇到在for循環(huán)使用一個(gè)異步操作,這也是一個(gè)很常見的面試題。在如下場景,你需要將一批id從0到9的用戶名數(shù)據(jù)請求回來,并將id做為key,name為value塞到一個(gè)對象里,代碼可能會(huì)是這樣的

var users = {};
for (var i = 0; i < 10; i++) {
  ajax.get(`/api/userName/${i}`).then(res => {
      users[i] = res.name;
  });
}

最后users對象的數(shù)據(jù)結(jié)果并非我們所想的那樣,而是{10: '最后一個(gè)請求回來的用戶名'}。這是因?yàn)楫惒秸埱蟮脑,由于事件?duì)列機(jī)制,for循環(huán)會(huì)先全部執(zhí)行完成,而異步請求會(huì)在后面的不定時(shí)間內(nèi)完成,并且調(diào)用then方法被事件隊(duì)列排在了后面,而此時(shí)在任意一個(gè)then方法內(nèi)i變量已經(jīng)在最后一次循環(huán)中被遞增到等于10,在不停的調(diào)用then方法時(shí),users對象key為10的value會(huì)被一直改寫直到最后一個(gè)請求結(jié)束。

使用 let 塊級(jí)作用域解決

var users = {};
for (let i = 0; i < 10; i++) {
  ajax.get(`/api/userName/${i}`).then(res => {
      users[i] = res.name;
  });
}

將遞增變量i使用let聲明即可解決,let 語句聲明一個(gè)塊級(jí)作用域的本地變量,花括號(hào)里是一個(gè)塊,每次循環(huán)都使用該塊級(jí)作用域中的變量,可以看作每次循環(huán)的塊都是相互隔離的,變量只會(huì)在該作用域內(nèi)生效。

使用函數(shù)閉包作用域解決

var users = {};
for (var i = 0; i < 10; i++) {
  (function () {
      var j = i;
      ajax.get(`/api/user/${j}`).then(res => {
        users[j] = res.name;
     });
  }());
}

我們將異步方法包在一個(gè)立即執(zhí)行函數(shù)里面,通過var j聲明的變量去承接在該函數(shù)內(nèi)i變量的值,由于立即執(zhí)行函數(shù)形成了一個(gè)閉包作用域,變量j在每一個(gè)作用域內(nèi)都是單獨(dú)存在的。

使用函數(shù)參數(shù)作用域解決

var users = {};
for (var i = 0; i < 10; i++) {
  (function (value) {
      ajax.get(`/api/user/${value}`).then(res => {
        users[value] = res.name;
     });
  }(i));
}

將變量i作為立即執(zhí)行函數(shù)的參數(shù)傳遞進(jìn)來,參數(shù)也具有各自的作用域,函數(shù)參數(shù)只在函數(shù)內(nèi)起作用,是局部變量。

2.for in循環(huán)(es5)

for...in語句以任意順序遍歷一個(gè)對象的可枚舉屬性,遍歷的順序可能因?yàn)g覽器實(shí)現(xiàn)方式有所不同。所遍歷的內(nèi)容可以是一個(gè)對象、數(shù)組、字符串、arguments等。使用Object.defineProperty方法可以為對象屬性定義是否可以枚舉。

枚舉

在JavaScript中,對象的屬性分為可枚舉和不可枚舉之分,它們是由屬性的enumerable值決定的。可枚舉性決定了這個(gè)屬性能否被for…in查找遍歷到。對象的propertyIsEnumerable方法可以判斷此對象是否包含某個(gè)屬性,并且返回這個(gè)屬性是否可枚舉。
Object, Array, Number等內(nèi)置的方法和屬性都是不可枚舉的

const obj = {};
Object.defineProperty(obj, 'city', {value: '北京', enumerable: false});
const isEnumerable = obj.propertyIsEnumerable('city');
console.log(obj);           // {city: "北京"}
console.log(isEnumerable);  //false

for...in可以遍歷可枚舉但對象,包括不是它本身但存在于原型鏈上的屬性。

const obj = {a:1, b:2, c:3};
Object.defineProperty(obj, 'd', {value: 4, enumerable: false})
obj.__proto__ = {name: 'ricky', age: '25'}

console.log(obj)

console.log('=====for in=======')
for (var prop in obj) {
  console.log(prop, obj[prop]);
}
console.log('=====Object.keys=======')
console.log(Object.keys(obj))
console.log('=====Object.getOwnPropertyNames=======')
console.log(Object.getOwnPropertyNames(obj))
console.log('=====Object.values=======')
console.log(Object.values(obj))
console.log('=====Object.entries=======')
console.log(Object.entries(obj))

輸出結(jié)果

3515977636-5bfb730c0be2b_articlex.png

我們先使用對象字面量的方式定義量一個(gè)obj,然后使用Object.defineProperty方法定義key為d的一個(gè)不可枚舉屬性,然后修改原型鏈__proto__,為其賦值了name, age兩個(gè)屬性。

  1. for in遍歷出除屬性名為d以外的所有可枚舉屬性,包括其原型鏈上的屬性

  2. Object.keys方法會(huì)返回一個(gè)由對象的自身可枚舉屬性名(key)組成的數(shù)組,其原型鏈上的屬性沒有被包含

  3. Object.getOwnPropertyNames方法會(huì)返回一個(gè)由對象的自身所有屬性名(key)組成的數(shù)組,包括可枚舉和不可枚舉的屬性

  4. Object.values方法會(huì)返回一個(gè)由對象的自身可枚舉屬性的值(value)組成的數(shù)組

  5. Object.entries方法會(huì)返回一個(gè)由對象的自身可枚舉屬性的鍵值對(key和value)組成的數(shù)組

for in會(huì)循環(huán)所有可枚舉的屬性,包括對象原型鏈上的屬性,循環(huán)會(huì)輸出循環(huán)對象的key,如果循環(huán)的是一個(gè)數(shù)組則會(huì)輸出下標(biāo)索引(index)。

in 運(yùn)算符

in 運(yùn)算符測試一個(gè)對象其自身和原型鏈中是否存在該屬性。

const obj = {name: 'ricky'};
Object.defineProperty(obj, 'city', {value: '北京', enumerable: false})
obj.__proto__ = {age: '25'}

console.log('name' in obj);   // true
console.log('city' in obj);   // true
console.log('age' in obj);    // true
console.log('sex' in obj);    // false

for of(es6) 循環(huán)可迭代對象

for of循環(huán)可迭代對象(包括 Array,Map,Set,String,TypedArray,類數(shù)組的對象(比如arguments對象、DOM NodeList 對象)、以及Generator生成器對象等)。

const array = [{a: 1}, {b: 2}, {c: 3}];
array.name = 'ricky';

console.log(array)
console.log('=====for of=======')
for (var prop of array) {
  console.log(prop);
}
console.log('=====for in=======')
for (var prop in array) {
  console.log(prop);
}

3814650713-5bfb730c15beb_articlex.png

for of 與 for in 不同處

  1. 與for in不同的是,for of不能循環(huán)普通對象({key: value})

  2. for of不會(huì)將循環(huán)對象中自定義的屬性內(nèi)容循環(huán)出來

  3. for in 是遍歷鍵名(key或index),而for of是遍歷鍵值(value)。

forEach、map 循環(huán)

forEach() 方法對數(shù)組的每個(gè)元素執(zhí)行一次提供的函數(shù),其中函數(shù)有三個(gè)參數(shù),依次為:當(dāng)前循環(huán)項(xiàng)的內(nèi)容、當(dāng)前循環(huán)的索引、循環(huán)的數(shù)組。

const array = ['a', 'b', 'c'];
array.forEach(function(value, index, data) {
    console.log(value, index, data);
});
// 輸出
// a  0  ["a", "b", "c"]
// b  1  ["a", "b", "c"]
// c  2  ["a", "b", "c"]

map() 方法會(huì)依次循環(huán)每一項(xiàng),并且返回結(jié)果映射組成一個(gè)新的數(shù)組。

const array = [1, 2, 3];
const newArray = array.map(function(value, index, data) {
    return value * 2;
});
console.log(newArray);
//輸出 [2, 4, 6]

使用forEach、map不能中斷循環(huán),方法會(huì)將每項(xiàng)內(nèi)容都執(zhí)行完成才會(huì)結(jié)束循環(huán)。

使用every或 some 提前結(jié)束循環(huán)

every循環(huán)當(dāng)返回false時(shí)循環(huán)即會(huì)結(jié)束, some方法在循環(huán)返回true時(shí)結(jié)束循環(huán),利用這個(gè)特性使用every和some方法都可以跳出循環(huán)。

const arr = [1, 2, 3, 4, 5];
arr.every(function(value){
   console.log(value);
   if(value === 3) {
   //every 循環(huán)當(dāng)返回false時(shí)結(jié)束循環(huán)
       return false;
   }
   return true //every 循環(huán)需要返回true,沒有返回值循環(huán)也會(huì)結(jié)束
});

arr.some(function(value){
   console.log(value);
   if(value === 3) {
   //some 循環(huán)當(dāng)返回true時(shí)結(jié)束循環(huán)
       return true;
   }
});

以上就是JavaScript中 for、for in、for of、forEach的用法小結(jié)(附代碼)的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!


網(wǎng)站建設(shè)是一個(gè)廣義的術(shù)語,涵蓋了許多不同的技能和學(xué)科中所使用的生產(chǎn)和維護(hù)的網(wǎng)站。

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統(tǒng)下載排行

在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美
  • <li id="86scu"><menu id="86scu"></menu></li>
    <li id="86scu"></li>
    <button id="86scu"></button>
  • <s id="86scu"></s><button id="86scu"><menu id="86scu"></menu></button>
  • 春日野结衣av| 男插女免费视频| 青青青在线视频播放| 天天色天天综合网| 青青草久久伊人| 久久久久久久久久毛片| 亚洲图色中文字幕| 欧美一级小视频| 欧美性受xxxxxx黑人xyx性爽| www.色偷偷.com| 午夜免费福利视频在线观看| 香蕉视频999| 97精品国产97久久久久久粉红| 国产免费色视频| 男人天堂a在线| 成年人在线看片| 鲁一鲁一鲁一鲁一av| 久久精品国产露脸对白| 糖心vlog在线免费观看| 免费看毛片的网址| 激情视频综合网| 久久久精品高清| 日本aa在线观看| 无码无遮挡又大又爽又黄的视频| 黄色国产小视频| 精品一区二区成人免费视频| 无码 制服 丝袜 国产 另类| 日日碰狠狠丁香久燥| 亚洲黄色av片| 91丨porny丨探花| 亚洲欧美久久久久| 日韩免费在线观看av| 亚洲爆乳无码专区| 国产精品无码乱伦| 免费在线激情视频| 妞干网这里只有精品| 无码aⅴ精品一区二区三区浪潮| 天天综合网日韩| 成人在线观看你懂的| 999热精品视频| www.欧美日本| 免费看又黄又无码的网站| 亚洲精品成人在线播放| 欧美 日韩 国产在线观看| 欧美精品色视频| 午夜免费一区二区| 欧美日韩一道本| www.激情网| 日日噜噜夜夜狠狠久久丁香五月| 999香蕉视频| 免费观看国产精品视频| 9l视频自拍9l视频自拍| www.精品在线| 人妻丰满熟妇av无码区app| 国产av熟女一区二区三区| 天天综合天天添夜夜添狠狠添| 女人扒开屁股爽桶30分钟| 黄色一级视频在线播放| 亚洲爆乳无码精品aaa片蜜桃| 欧美一级xxxx| www.超碰97.com| 激情视频免费网站| 亚洲这里只有精品| 五月婷婷狠狠操| 毛片毛片毛片毛片毛片毛片毛片毛片毛片| 亚洲精品久久久久久久蜜桃臀| 一本—道久久a久久精品蜜桃| 亚洲免费成人在线视频| 中文字幕1234区| 日韩精品在线播放视频| 红桃视频一区二区三区免费| 久久精品一二三四| 女人床在线观看| 久久这里只有精品18| 日韩小视频在线播放| 99蜜桃臀久久久欧美精品网站| 男女av免费观看| 男女污污的视频| 91社在线播放| 日韩精品在线观看av| 欧美日韩一道本| 日韩av片网站| 国产又粗又猛大又黄又爽| 国产精品视频网站在线观看 | 色噜噜狠狠一区二区| av噜噜在线观看| 免费成人深夜夜行网站视频| 黄网站色视频免费观看| 国产亚洲精品网站| 污网站在线免费| 久久99久久久久久| 日本成人在线免费视频| 色综合五月婷婷| 丰满少妇久久久| 在线免费观看av网| 久久av综合网| 亚洲娇小娇小娇小| 欧美乱大交xxxxx潮喷l头像| 那种视频在线观看| 女女同性女同一区二区三区按摩| 免费超爽大片黄| 手机免费看av网站| 九一国产精品视频| 99re99热| 国产高清视频网站| 波多野结衣乳巨码无在线| 欧美国产日韩另类 | 国产视频九色蝌蚪| 一级黄色免费在线观看| 日本熟妇人妻中出| 国产毛片久久久久久国产毛片| 日本在线观看免费视频| www.av毛片| 天天久久综合网| 天天爱天天操天天干| 国产毛片视频网站| xxxxxx在线观看| 欧美一级特黄aaa| caoporn超碰97| 黄在线观看网站| 日本丰满少妇xxxx| 久久久久久久香蕉| 警花观音坐莲激情销魂小说| 日韩va在线观看| 一本岛在线视频| 无人在线观看的免费高清视频| 久久久性生活视频| 国产日韩亚洲欧美在线| 国产一区二区三区播放| 美国av在线播放| 手机福利在线视频| 99热这里只有精品7| 午夜影院免费版| 国产资源第一页| 久久手机在线视频| 你真棒插曲来救救我在线观看| 免费高清一区二区三区| 国产自产在线视频| 乱妇乱女熟妇熟女网站| 欧美亚洲一二三区| 欧美一级黄色影院| 91女神在线观看| 在线无限看免费粉色视频| aaaaaaaa毛片| 五月天激情图片| www.日本少妇| 蜜臀久久99精品久久久酒店新书 | 自拍日韩亚洲一区在线| 国精产品一区一区三区视频| 亚洲熟妇无码一区二区三区导航| 人妻av中文系列| 色一情一乱一伦一区二区三区日本| 黑鬼大战白妞高潮喷白浆| 亚洲性图一区二区| 日本成人在线不卡| 成人小视频在线看| 亚洲无在线观看| 国产玉足脚交久久欧美| 成人午夜激情av| 天堂а√在线中文在线| 欧美亚洲另类色图| 中文 日韩 欧美| 日韩av高清在线看片| 尤物国产在线观看| 欧美极品欧美精品欧美| 羞羞的视频在线| 日韩欧美不卡在线| 日韩高清第一页| 午夜免费福利小电影| 国产又粗又长又爽又黄的视频| 国产精品999视频| 手机精品视频在线| 国产a级片免费观看| 欧美一级特黄aaaaaa在线看片| 久久久噜噜噜www成人网| 女同性恋一区二区| 污视频网站观看| 激情综合在线观看| 97久久国产亚洲精品超碰热| 午夜免费福利在线| 黄色一级视频片| 久久亚洲a v| 超碰成人在线免费观看| 亚洲欧美日韩一级| 国产a视频免费观看| 日本手机在线视频| 少妇一晚三次一区二区三区| 久久国产这里只有精品| 麻豆av免费在线| 欧美亚洲精品一区二区| 日本大片免费看| 7777在线视频| 一级黄色免费在线观看| 97人人爽人人| 日韩高清第一页| 亚洲免费黄色录像| 亚洲天堂av一区二区| 五月婷婷六月合| 91精品无人成人www| 91极品视频在线观看|