您好,登錄后才能下訂單哦!
這篇文章主要介紹Javascript ES6中對象類型Sets怎么用,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
介紹
ECMAScript 6(以下簡稱ES6)是JavaScript語言的下一代標準。因為當前版本的ES6是在2015年發布的,所以又稱ECMAScript 2015。
Sets 是ES6(ES2015)中一個新的對象類型,用來創建一系列唯一值的集合。集合中的值可以是簡單的原始類型如字符串(strings)或整數(integers),也可以是更復雜的對象類型如對象字面量或者數組。
基本方法
下面是基本的set及其方法(add, size, has, forEach, delete, clear)的簡單示例:
let animals = new Set(); animals.add('?'); animals.add('?'); animals.add('?'); animals.add('?'); console.log(animals.size); // 4 animals.add('?'); console.log(animals.size); // 4 console.log(animals.has('?')); // true animals.delete('?'); console.log(animals.has('?')); // false animals.forEach(animal => { console.log(`Hey ${animal}!`); }); // Hey ?! // Hey ?! // Hey ?! animals.clear(); console.log(animals.size); // 0
初始化
下面是另一個將數組作為初始值傳進set的示例。需要主要的是初始化的數組是如何被解構的,但是隨后添加的數組將以數組的形式存在:
let myAnimals = new Set(['?', '?', '?', '?']); myAnimals.add(['?', '?']); myAnimals.add({ name: 'Rud', type: '?' }); console.log(myAnimals.size); // 4 myAnimals.forEach(animal => { console.log(animal); }); // ? // ? // ["?", "?"] // Object { name: "Rud", type: "?" }
字符串也是一個有效的迭代,所以也可以被傳入來初始化一個set:
console.log('Only unique characters will be in this set.'.length); // 43 let sentence = new Set('Only unique characters will be in this set.'); console.log(sentence.size); // 18
For...of遍歷
除了在一個set上可以使用forEach外,for...of循環也可以被用來遍歷sets:
let moreAnimals = new Set(['?', '?', '?', '?']); for (let animal of moreAnimals) { console.log(`Howdy ${ animal }`); } // Howdy ? // Howdy ? // Howdy ? // Howdy ?
Keys 和 Values
Sets也有keys和values方法,由于keys是values的別名,所以兩個方法其實是完成一樣的事情。使用兩者中的任何一個方法都會返回一個新的可迭代的對象,該對象的值與添加到集合中的順序相同。
let partyItems = new Set(['?', '?', '?']); let items = partyItems.values(); console.log(items.next()); console.log(items.next()); console.log(items.next()); console.log(items.next().done); // Object { // done: false, // value: "?" // } // Object { // done: false, // value: "?" // } // Object { // done: false, // value: "?" // } // true
以上是“Javascript ES6中對象類型Sets怎么用”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。