国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

JavaScript中 for、for in、for of、forEach等使用總結

hlcc / 723人閱讀

摘要:等內置的方法和屬性都是不可枚舉的北京北京可以遍歷可枚舉但對象,包括不是它本身但存在于原型鏈上的屬性。北京循環可迭代對象循環可迭代對象包括,,,,,類數組的對象比如對象對象以及生成器對象等。

在JavaScript中,我們經常需要去循環迭代方法操作數組對象等,常見等循環方法有 forfor infor offorEach等。

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

輸出結果

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

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

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

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

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

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

for of 與 for in 不同處

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

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

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

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/99408.html

相關文章

  • javascript遍歷方法總結

    摘要:總之,是用來循環帶有字符串的對象的方法。循環里引入了一種新的循環方法,它就是循環,它既比傳統的循環簡潔,同時彌補了和循環的短板。 forEach 循環 JavaScript誕生已經有20多年了,我們一直使用的用來循環一個數組的方法是這樣的: for (var index = 0; index < myArray.length; index++) { console.log(myAr...

    BothEyes1993 評論0 收藏0
  • javascript的幾種常見遍歷數據結構的語法

    摘要:接觸這么多年,第一次總結一下它的遍歷語法。而且你必須借助特定的結構才能遍歷數據結構。它的作用是遍歷對象的鍵名。建議僅在遍歷數組的時候使用。另一個優點是,它可以遍歷任何部署了接口的數據結構,甚至是非的數據類型,即自己定義的數據結構。 接觸JavaScript這么多年,第一次總結一下它的遍歷語法。以前我大部分時間都在老版本的JavaScript下寫代碼,所以大部分時間都是用for...in...

    kohoh_ 評論0 收藏0
  • JavaScript 的 4 種數組遍歷方法: for VS forEach() VS for/in

    摘要:對于,除非使用箭頭函數,它的回調函數的將會變化。使用測試下面的代碼,結果如下打印打印要點使用的規則要求所有回調函數必須使用箭頭函數。 譯者按: JS 騷操作。 原文:For vs forEach() vs for/in vs for/of in JavaScript 譯者: Fundebug 本文采用意譯,版權歸原作者所有 我們有多種方法來遍歷 JavaScript 的數組或者...

    joyqi 評論0 收藏0
  • JavaScript:遍歷

    摘要:中可以實現遍歷的數據類型主要是對象,其中包括普通對象與數組。遍歷器是一種接口,為各種不同的數據結構提供統一的訪問機制。實例五遍歷器對象實例五是的遍歷過程,通過手動調用其對象的方法實現信息獲取。為每個數組元素執行函數。 前言 ??將依據自身痛點學習,計劃對原生JavaScript寫一個系統,本文為第一篇,感興趣的同學可以關注個人公眾號:ZeroToOneMe,或者github博客,將持續...

    ThinkSNS 評論0 收藏0
  • js遍歷之for forEach in of

    摘要:語法參數當前遍歷項。遍歷的范圍在第一次調用前就會確定。已刪除的項不會被遍歷到。的是由提出的,目的是作為遍歷所有數據結構的統一方法。不僅可以遍歷數組,還可以遍歷結構,某些類似數組的對象如對象對象,對象,以及字符串。 即使是最簡單的循環,其中也深藏學問 ECMAScript5(es5)有三種for循環 簡單for for in forEach ECMAScript6(es6)新增 fo...

    yeyan1996 評論0 收藏0

發表評論

0條評論

hlcc

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<