에뮬레이션 구현 ES6의 set 클래스
function Set() {
var items = {};
// this.has = function(value){
// return value in items;
// }
this.has = function(value){
return items.hasOwnProperty(value);
},
this.add = function(value){
if (!this.has(value)) {
items[value] = value;
return true;
}
return false;
},
this.remove = function(value){
if (this.has(value)) {
delete value;
return true;
}
return false;
},
this.clear = function(){
items={};
},
this.size = function(){
var count = 0;
for(var prop in items){
if (items.hasOwnProperty(prop)) {
++count;
}
}
return count;
},
this.values= function(){
var values = [];
for(var value in items){
if (items.hasOwnProperty(value)) {
values.push(value);
}
}
return values;
},
//
this.union = function(otherSet){
var unionSet = new Set();
var values = this.values();
for (var i = 0; i < values.length; i++) {
unionSet.add(values[i]);
}
values = otherSet.values();
for (var i = 0; i < values.length; i++) {
unionSet.add(values[i]);
}
return unionSet;
},
//
this.intersection = function(otherSet){
var intersection = new Set();
var values = this.values();
for (var i = 0; i < values.length; i++) {
if (otherSet.has(values[i])) {
intersection.add(values[i]);
}
}
return intersection;
},
//
this.difference = function(otherSet){
var difference = new Set();
var values = this.values();
for (var i = 0; i < values.length; i++) {
if (!otherSet.has(values[i])) {
difference.add(values[i]);
}
}
return difference;
},
//
this.subset = function(otherSet){
var values = this.values();
if (this.size() > otherSet.size()) {
return false;
}
else{
for (var i = 0; i < values.length; i++) {
if (!otherSet.has(values[i])) {
return false;
}
}
return true;
}
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.