集合是由一组无序且唯一(即不能重复)的项组成。 可以把集合想象成一个既没有重复元素,也没有顺序概念的数组。
function Set() {
var items = {};
}
this.has = function(value) {
return items.hasOwnProperty(value);
};
this.add = function(value) {
//检查给定的value是否存在集合中,如果不存在,添加并返回true,反之返回false
if(!this.has(value)) {
items[value] = value;
return true;
}
return false;
};
this.remove = function(value) {
//给定的value是否存在于集合中,如果存在,就从这个集合中删除value,返回true,表示值被移除;否则返回false
if(this.has(value)) {
delete items[value];
return true;
}
return false;
};
this.clear = function() {
items = {};
};
this.size = function() {
//使用Object.keys()方法
return Object.keys(items).length;
};
this.values = function() {
//使用Object.keys()方法提取items对象的所有属性
return Object.keys(items);
};
全部代码:
function Set() {
var items = {};
//has方法如果值在集合中,返回true,否则返回false
this.has = function(value) {
return items.hasOwnProperty(value);
};
//add方法向集合添加一个新的项
this.add = function(value) {
//检查给定的value是否存在集合中,如果不存在,添加并返回true,反之返回false
if(!this.has(value)) {
items[value] = value;
return true;
}
return false;
};
//remove方法,从集合中移除一个值
this.remove = function(value) {
//给定的value是否存在于集合中,如果存在,就从这个集合中删除value,返回true,表示值被移除;否则返回false
if(this.has(value)) {
delete items[value];
return true;
}
return false;
};
//clear方法,移除集合中的所有项
this.clear = function() {
items = {};
};
//size方法返回集合中所包含元素的数量
this.size = function() {
//使用Object.keys()方法
return Object.keys(items).length;
};
//values方法,返回一个包含集合中所有值的数组
this.values = function() {
//使用Object.keys()方法提取items对象的所有属性
return Object.keys(items);
};
}
var set = new Set();
set.add(1);
console.log(set.values()); // ["1"]
console.log(set.has(1)); // true
console.log(set.size()); // 1
参考学习:
学习javascript数据结构与算法 数据结构与算法javascript描述