想不通,为什么《学习Javascript数据结构与算法》为什么会设计这样的一小节
仅仅是对原生的功能稍微扩充了一下。不说了,为了保持完整性,把代码贴出来吧
/*
使用字典来存储唯一值
*/
function Dictionary() {
var items = {};
/*向字典中添加元素, 或者更新一个元素*/
this.set = function (key, value) {
items[key] = value;
}
/*从字典中移除元素*/
this.remove = function (key) {
if(!this.has(key)) {
return false;
}
delete items[key];
return true;
}
/*判断字典中是否存在某元素*/
this.has = function (key) {
if(key in items) {
return true;
}
return false;
}
/*通过键值查找元素并返回*/
this.get = function (key) {
if(!this.has(key)) {
return false;
}
return items[key];
}
/*清除字典*/
this.clear = function () {
items = {};
}
/*字典中包含的元素数量*/
this.size = function () {
var cnt =0;
for(var name in items) {
cnt++;
}
return cnt;
}
/*字典中所有包含的键名以数组返回*/
this.keys = function () {
var arr = [];
for(var name in items) {
if(items.hasOwnProperty(name)) {
arr.push(name);
}
}
return arr;
}
/*字典中所有包含的键值以数组返回*/
this.values = function () {
var arr = [];
for(var name in items) {
arr.push(items[name]);
}
return arr;
}
/*为了查看方便,定义一个辅助函数*/
this.getItems = function () {
return items;
}
}
var d = new Dictionary();
d.set("name", "Louis");
d.set("age", 25);