国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

JavaScript中for、forin、forof、forEach的用法小結(附代碼)

來源:懂視網 責編:小采 時間:2020-11-27 19:28:45
文檔

JavaScript中for、forin、forof、forEach的用法小結(附代碼)

JavaScript中for、forin、forof、forEach的用法小結(附代碼):本篇文章給大家帶來的內容是關于JavaScript中 for、for in、for of、forEach的用法小結(附代碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。在JavaScript中,我們經常需要去循環迭代方法操作數組對象等,常見等循環方法有 for、
推薦度:
導讀JavaScript中for、forin、forof、forEach的用法小結(附代碼):本篇文章給大家帶來的內容是關于JavaScript中 for、for in、for of、forEach的用法小結(附代碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。在JavaScript中,我們經常需要去循環迭代方法操作數組對象等,常見等循環方法有 for、
本篇文章給大家帶來的內容是關于JavaScript中 for、for in、for of、forEach的用法小結(附代碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

在JavaScript中,我們經常需要去循環迭代方法操作數組對象等,常見等循環方法有 for、for in、for of、forEach等。

1.for循環

for循環是最基礎常見的一種循環,圓括號中需要三個表達式,由分號分隔,最后面是一個花括號的塊語句。

for (var i = 0; i <10; i++){
 if (i === 5) {
 continue; //跳出當前循環
 } else if (i === 8) {
 break; //結束循環
 }
 console.log(i);
}

for循環中的語句

continue 語句用來跳出本次循環,但會繼續執行后面的循環。
break 語句用來結束循環,后面的循環不會再執行。
return 并不能用來跳出for循環,return語句只能出現在函數體內,它會終止函數的執行,并返回一個指定的值。

使用for循環中遇到的問題

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

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

最后users對象的數據結果并非我們所想的那樣,而是{10: '最后一個請求回來的用戶名'}。這是因為異步請求的原因,由于事件隊列機制,for循環會先全部執行完成,而異步請求會在后面的不定時間內完成,并且調用then方法被事件隊列排在了后面,而此時在任意一個then方法內i變量已經在最后一次循環中被遞增到等于10,在不停的調用then方法時,users對象key為10的value會被一直改寫直到最后一個請求結束。

使用 let 塊級作用域解決

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

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

使用函數閉包作用域解決

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

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

使用函數參數作用域解決

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

將變量i作為立即執行函數的參數傳遞進來,參數也具有各自的作用域,函數參數只在函數內起作用,是局部變量。

2.for in循環(es5)

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

枚舉

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

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))

輸出結果

3515977636-5bfb730c0be2b_articlex.png

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

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

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

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

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

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

for in會循環所有可枚舉的屬性,包括對象原型鏈上的屬性,循環會輸出循環對象的key,如果循環的是一個數組則會輸出下標索引(index)。

in 運算符

in 運算符測試一個對象其自身和原型鏈中是否存在該屬性。

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) 循環可迭代對象

for of循環可迭代對象(包括 Array,Map,Set,String,TypedArray,類數組的對象(比如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不能循環普通對象({key: value})

  2. for of不會將循環對象中自定義的屬性內容循環出來

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

forEach、map 循環

forEach() 方法對數組的每個元素執行一次提供的函數,其中函數有三個參數,依次為:當前循環項的內容、當前循環的索引、循環的數組。

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() 方法會依次循環每一項,并且返回結果映射組成一個新的數組。

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

使用forEach、map不能中斷循環,方法會將每項內容都執行完成才會結束循環。

使用every或 some 提前結束循環

every循環當返回false時循環即會結束, some方法在循環返回true時結束循環,利用這個特性使用every和some方法都可以跳出循環。

const arr = [1, 2, 3, 4, 5];
arr.every(function(value){
 console.log(value);
 if(value === 3) {
 //every 循環當返回false時結束循環
 return false;
 }
 return true //every 循環需要返回true,沒有返回值循環也會結束
});

arr.some(function(value){
 console.log(value);
 if(value === 3) {
 //some 循環當返回true時結束循環
 return true;
 }
});

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JavaScript中for、forin、forof、forEach的用法小結(附代碼)

JavaScript中for、forin、forof、forEach的用法小結(附代碼):本篇文章給大家帶來的內容是關于JavaScript中 for、for in、for of、forEach的用法小結(附代碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。在JavaScript中,我們經常需要去循環迭代方法操作數組對象等,常見等循環方法有 for、
推薦度:
標簽: in js 代碼
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 五月天婷婷视频 | 一区二区三区不卡视频 | 欧美中日韩在线 | 久久久精品一区二区三区 | 久久99精品国产99久久 | 国产精品亚洲精品观看不卡 | 99精品高清视频一区二区 | 国产日韩欧美视频在线 | 欧美在线一区二区三区精品 | 久久一 | 九九热精品在线观看 | 亚洲色图第1页 | 国产成人精品亚洲一区 | 亚洲日韩欧美视频 | 亚洲 另类 在线 欧美 制服 | 欧美黄色第一页 | 久久亚洲精品国产精品婷婷 | 亚洲伊人精品 | 精品国产一区二区三区免费看 | 无遮挡色视频 | 欧美精品久久久亚洲 | 天码毛片一区二区三区入口 | 国内高清久久久久久久久 | 大陆一级毛片 | 国产97在线观看 | 九九九国产在线 | 黄网站色视频免费观看 | 97国产精品欧美一区二区三区 | www.a级片 | 日韩欧美国产中文字幕 | 老司机精品视频一区二区 | 国产精品亚洲四区在线观看 | 国产免费高清视频在线观看不卡 | 夜夜操夜夜骑 | 99久久精品免费看国产 | 欧美一区二区三区四区视频 | 色精品一区二区三区 | 精品欧美一区二区三区 | 欧美日韩三区 | 国产成人手机在线好好热 | 国产国产成人精品久久 |