ES6-지도 및 세트
ES6는 두 가지 새로운 데이터 구조를 소개합니다- maps 과 sets. 그들에 대해 자세히 알아 보겠습니다.
지도
지도는 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
세트 반복
우리는 forEach 과 for..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 {{…}, {…}}