摘要:是對象,它的原型上有一個方法,可用用于遍歷迭代器取得原數組的。返回一個對象,對于有元素的數組,是用于指示迭代器是否完成在每次迭代時進行更新而且都是,直到迭代器結束才是。是一個的數組,是返回的迭代器中的元素值。
1.什么是entry
entries() 方法返回一個新的Array Iterator對象,該對象包含數組中每個索引的鍵/值對。
2.示例
Object.entries()
傳入對象
const obj = { foo: "bar", baz: 42 }; Object.entries(obj) //輸出 [ ["foo", "bar"], ["baz", 42] ]
Array.entries()
傳入數組
const arr = ["a", "b", "c"]; console.log(Object.entries(arr)); // [[ "0", "a" ], [ "1", "b" ], [ "2", "c" ] ] const arr1 = [{ a: 1 }, 2, 3]; console.log(Object.entries(arr1)); // [["0", { a: 1 }], ["1", "2"], ["2", "3"]] const arr2 = [{ a: 1 }, { b: 2 }, { c: 3 }]; console.log(Object.entries(arr2)); // [["0", { a: 1 }], ["1", { b: 2 }], ["2", { c: 3 }]]
將 Object 轉化為 Map
new Map() 構造函數接受一個可迭代的 entries 。 借助 Object.entries 方法你可以很容易的將 Object 轉換為 Map:
const obj2 = { foo: "bar", baz: "abc" }; console.log(Object.entries(obj2)); // [["foo", "bar"], ["baz", "abc"]] const map = new Map(Object.entries(obj2)); console.log(map); // Map {"foo" => "bar", "baz" => "abc"}3. arr.entries()
返回一個新的 Array 迭代器對象。Array Iterator是對象,它的原型(__proto__:Array Iterator)上有一個next方法,可用用于遍歷迭代器取得原數組的[key,value]。
var array1 = ["a", "b", "c"]; var iterator1 = array1.entries(); console.log(iterator1.next().value); // expected output: Array [0, "a"] console.log(iterator1.next().value); // expected output: Array [1, "b"]
Array Iterator
var arr = ["a", "b", "c"]; var iterator = arr.entries(); console.log(iterator); /*Array Iterator {} __proto__:Array Iterator next:? next() Symbol(Symbol.toStringTag):"Array Iterator" __proto__:Object */
iterator.next()
var arr = ["a", "b", "c"]; var iterator = arr.entries(); console.log(iterator.next()); // { value: [ 0, "a" ], done: false } // iterator.next()返回一個對象,對于有元素的數組, // 是next{ value: Array(2), done: false }; // next.done 用于指示迭代器是否完成:在每次迭代時進行更新而且都是false, // 直到迭代器結束done才是true。 // next.value是一個["key","value"]的數組,是返回的迭代器中的元素值。
iterator.next方法運行
var arr = ["a", "b", "c"]; var iter = arr.entries(); var a = []; // for(var i=0; i< arr.length; i++){ // 實際使用的是這個 for(var i=0; i< arr.length+1; i++){ // 注意,是length+1,比數組的長度大 var tem = iter.next(); // 每次迭代時更新next console.log(tem.done); // 這里可以看到更新后的done都是false if(tem.done !== true){ // 遍歷迭代器結束done才是true console.log(tem.value); a[i]=tem.value; } } console.log(a); // false // [ 0, "a" ] // false // [ 1, "b" ] // false // [ 2, "c" ] // true // [ [ 0, "a" ], [ 1, "b" ], [ 2, "c" ] ]
二維數組按行排序
function sortArr(arr) { var goNext = true; var entries = arr.entries(); while (goNext) { var result = entries.next(); if (result.done !== true) { result.value[1].sort((a, b) => a - b); goNext = true; } else { goNext = false; } } return arr; } var arr = [[1,34],[456,2,3,44,234],[4567,1,4,5,6],[34,78,23,1]]; sortArr(arr);
使用for…of 循環
var arr = ["a", "b", "c"]; var iterator = arr.entries(); // undefined for (let e of iterator) { console.log(e); } // [0, "a"] // [1, "b"] // [2, "c"]
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/105319.html
摘要:返回值給定對象自身可枚舉屬性的鍵值對數組。描述返回一個數組,其元素是與直接在上找到的可枚舉屬性鍵值對相對應的數組。屬性的順序與通過手動循環對象的屬性值所給出的順序相同。借助方法你可以很容易的將轉換為你可以使用下面列出的簡易。 Object.entries() Object.entries()方法返回一個給定對象自身可枚舉屬性的鍵值對數組,其排列與使用 for...in 循環遍歷該對象時...
摘要:當普通對象要轉換成時就很有用,因為返回的格式與構造函數接受的格式完全相同。使用常規的構造函數可以將一個二維鍵值對數組轉換成一個對象。在和早期標準中,根本沒有指定屬性的順序。此函數還可以輕松地將純對象屬性映射到對象中。 為了保證的可讀性,本文采用意譯而非直譯。 想閱讀更多優質文章請猛戳GitHub博客,一年百來篇優質文章等著你! 自身可枚舉屬性 Object.keys() 方法會返回一個...
摘要:方法就是的逆操作,作用是將一個鍵值對數組轉化為一個對象同樣的該方法也已經成為中提案在介紹之前,回顧一下的用法。 Object.fromEntries 方法就是 entries 的逆操作,作用是將一個鍵值對數組轉化為一個對象 同樣的該方法也已經成為 ES10 中 stage4 提案: showImg(https://segmentfault.com/img/remote/14600000...
摘要:中雙感嘆號的作用一般用于將后面的表達式強制轉化為布爾類型。通過實現類式繼承繼承對象已經原型對象屬性父類父類的方法子類調用父類的構造函數。 js基礎對象屬性方法 Object.keys() Object.keys()方法會返回一個由一個給定對象的自身可枚舉屬性組成的數組,數組中屬性名的排列順序和使用 for...in 循環遍歷改對象時返回的順序一致(兩者的主要區別是一個for-in 循環...
showImg(https://segmentfault.com/img/remote/1460000019258913?w=2933&h=1955); 1. Object.is() 用來解決在ES5中 兩種相等運算符的缺點。用來比較兩個值是否嚴格相等,行為和(===)基本一致。 在ES5中判斷兩個值是否相等,只能用(==)相等運算符和(===)嚴格相等運算符,但是這兩貨都有缺點,前者 兩邊的值都...
閱讀 834·2019-08-30 14:05
閱讀 1724·2019-08-30 11:08
閱讀 3226·2019-08-29 15:41
閱讀 3601·2019-08-23 18:31
閱讀 1523·2019-08-23 18:29
閱讀 556·2019-08-23 14:51
閱讀 2115·2019-08-23 13:53
閱讀 2135·2019-08-23 13:02