首頁 > web前端 > js教程 > 主體

ES6之set-map資料結構的實例詳解

零下一度
發布: 2017-06-26 09:12:31
原創
1838 人瀏覽過

一、set資料結構(使用 new來建立一個set集合  透過add方法加入元素  透過size來取得set集合的長度) 

#
{
  let list = new Set();
  list.add(5);
  list.add(7);

  console.log('size',list.size);
}
登入後複製

  還有另外一種初始化的方式(透過直接把陣列傳進去)

{
  let arr = [1,2,3,4,5];
  let list = new Set(arr);

  console.log('size',list.size);
}
登入後複製

  #set裡面的元素不可以重複(可以透過set的這個特性來進行陣列去重,注意:轉換過程中不會進行資料型別轉換)

{
  let list = new Set();
  list.add(1);
  list.add(2);
  list.add(1);//不会报错 只是不会生效

  console.log('list',list);

  let arr=[1,2,3,1,'2'];
  let list2=new Set(arr);

  console.log('unique',list2);
}
登入後複製

  set的一些方法(add , delete,clear,has) 

{
  let arr=['add','delete','clear','has'];
  let list=new Set(arr);

  console.log('has',list.has('add'));//是否包含
  console.log('delete',list.delete('add'),list);//清空
  list.clear();
  console.log('list',list);
}
登入後複製

  set的遍歷(keys和values回傳的都是set裡面的值)

{
  let arr=['add','delete','clear','has'];
  let list=new Set(arr);  for(let key of list.keys()){
    console.log('keys',key);
  }  for(let value of list.values()){
    console.log('value',value);
  }  for(let [key,value] of list.entries()){
    console.log('entries',key,value);
  }

  list.forEach(function(item){console.log(item);})
}
登入後複製

  WeakSet(裡面的元素只能是對象,並且不會偵測所新增的物件是否在別處引用,沒有size clear 不支援遍歷)

{
  let weakList=new WeakSet();

  let arg={};

  weakList.add(arg);  // weakList.add(2);
  console.log('weakList',weakList);
}
登入後複製

二、Map資料結構(Map是透過key/value設定的,所以設定用set方法,取得使用get方法)  

{
  let map = new Map();
  let arr=['123'];

  map.set(arr,456);

  console.log('map',map,map.get(arr));
}
登入後複製

  Map的另一個定義方式(同時size delete clear方法一樣)

{
  let map = new Map([['a',123],['b',456]]);
  console.log('map args',map);
  console.log('size',map.size);
  console.log('delete',map.delete('a'),map);
  console.log('clear',map.clear(),map);
}
登入後複製

  weakMap資料結構(和setMap的特性一致)

{
  let weakmap=new WeakMap();

  let o={};
  weakmap.set(o,123);
  console.log(weakmap.get(o));
}
登入後複製

    

################################################################################################################

以上是ES6之set-map資料結構的實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!