ES6-지도 및 세트

ES6는 두 가지 새로운 데이터 구조를 소개합니다- mapssets. 그들에 대해 자세히 알아 보겠습니다.

지도

지도는 key-value pairs. 지도는 개체와 유사합니다. 그러나지도와 개체 간에는 약간의 차이가 있습니다. 이들은 아래에 나열되어 있습니다-

Sr. 아니요 목적 지도
1 키는 객체 유형일 수 없습니다. 키는 모든 유형이 될 수 있습니다.
2 키는 주문되지 않습니다. 키가 주문됩니다
반복 할 수 없음 반복 가능

통사론

Map의 구문은 다음과 같습니다.

let map = new Map([iterable])
let map = new Map()

다음 예제는 반복 가능한 생성자를 사용하여지도를 만듭니다.

<script>
   let andy = {ename:"Andrel"},
      varun = {ename:"Varun"},
      prijin = {ename:"Prijin"}
   let empJobs = new Map([
   [andy,'Software Architect'],
   [varun,'Developer']]
   );
   console.log(empJobs)
</script>

위 코드의 출력은 다음과 같습니다.

{{…} => "Software Architect", {…} => "Developer"}

지도 크기 확인

size 속성은지도에 저장된 값의 수를 결정하는 데 사용할 수 있습니다.

통사론

지도의 크기를 확인하는 구문은 다음과 같습니다.

map_name.size

<script>
   let daysMap = new Map();
   daysMap.set('1', 'Monday');
   daysMap.set('2', 'Tuesday');
   daysMap.set('3', 'Wednesday');
   console.log(daysMap.size);
</script>

위 코드의 출력은 다음과 같습니다.

3

다음은지도를 조작하는 데 사용할 수있는 몇 가지 일반적인 방법입니다.

Sr. 아니요 개체 및지도
1 set (키, 값)

매핑에 키와 값을 추가합니다.

2 get (키)

키가 일치하면 값을 반환합니다.

has (키)

지정된 키를 가진 요소가 있으면 true를 반환합니다. 그렇지 않으면 거짓을 반환

4 키 ()

지도 객체의 각 요소에 대한 키를 포함하는 반복기를 반환합니다.

5 값 ()

지도 객체의 각 요소에 대한 값을 포함하는 반복기를 반환합니다.

6 항목 ()

맵의 각 요소에 대한 키-값 쌍을 포함하는 반복기를 반환합니다.

7 삭제 (키)

Map 객체에서 지정된 요소를 제거합니다.

WeakMap

WeakMap은 작은 subset of map. 키는 약하게 참조되므로 기본이 아닐 수만 있습니다. 오브젝트 키에 대한 참조가 없으면 가비지 콜렉션의 대상이됩니다.

  • 반복 할 수 없음
  • 모든 키는 객체 유형입니다.

WeakMap은 키에 참조가없는 경우 가비지 수집을 허용합니다.

통사론

WeakMap의 구문은 다음과 같습니다.

new WeakMap([iterable])

예 1

<script>
   let emp = new WeakMap();
   emp.set(10,'Sachin');// TypeError as keys should be object
</script>

예 2

<script>
   let empMap = new WeakMap();
   // emp.set(10,'Sachin');// Error as keys should be object
   let e1= {ename:'Kiran'},
      e2 = {ename:'Kannan'},
      e3 = {ename:'Mohtashim'}

   empMap.set(e1,1001);
   empMap.set(e2,1002);
   empMap.set(e3,1003);

   console.log(empMap)
   console.log(empMap.get(e2))
   console.log(empMap.has(e2))
   empMap.delete(e1)
   console.log(empMap)
</script>

위 코드의 출력은 다음과 같습니다.

{{…} => 1002, {…} => 1003, {…} => 1001}
1002
true
{{…} => 1002, {…} => 1003}

세트

집합은 순서가 지정되지 않은 고유 값 모음입니다. 이 데이터 구조는 기본 및 객체 유형의 값을 포함 할 수 있습니다.

통사론

Set 구문은 다음과 같습니다.

new Set([iterable])
new Set()

<script>
   let names = new Set(['A','B','C','D']);
   console.log(names)
</script>

위 코드의 출력은 다음과 같습니다.

{"A", "B", "C", "D"}

세트의 크기 확인

Set 개체의 크기 속성은 Set의 요소 수를 쿼리하는 데 사용할 수 있습니다.

통사론

세트의 크기를 확인하는 구문은 다음과 같습니다.

set.size

<script>
   let names = new Set(['A','B','C','D']);
   console.log(names.size)
</script>

위 코드의 출력은 다음과 같습니다.

4

세트 반복

우리는 forEachfor..of세트를 반복하는 루프. 이것은 아래 예에 나와 있습니다.

<script>
   let names= new Set(['A','B','C','D']);
   //iterate using forEach
   console.log('forEach')
   names.forEach(n=>console.log(n))
   
   console.log('for of..')
   
   //iterate using for..of
   for(let n of names){
      console.log(n)
   }
</script>

위 코드의 출력은 다음과 같습니다.

forEach
A
B
C
D
for of..
A
B
C
D

다음 방법은 집합을 조작하는 데 사용할 수 있습니다-

Sr. 아니요 개체 및지도
1 추가 (요소)

세트에 요소를 추가합니다.

2 has (요소)

요소가 발견되면 true를 반환합니다. 그렇지 않으면 거짓을 반환

삭제 (요소)

세트에서 특정 요소 삭제

4 맑은()

세트에서 모든 요소를 ​​지 웁니다.

WeakSet

Weakset은 객체를 약하게 유지합니다. 즉, WeakSet에 저장된 객체는 참조되지 않는 경우 가비지 수집의 대상이됩니다. WeakSet은 반복 할 수 없으며get 방법.

<script>

   let e1 = {ename:'A'}
   let e2 ={ename:'B'}
   let e3 ={ename:'C'}

   let emps = new WeakSet();
   emps.add(e1);
   emps.add(e2)
   .add(e3);

   console.log(emps)
   console.log(emps.has(e1))
   emps.delete(e1);
   console.log(emps)
</script>

위 코드의 출력은 다음과 같습니다.

WeakSet {{…}, {…}, {…}}
true
WeakSet {{…}, {…}}