JS中MAP的使用

liangtiana 2010-11-24 02:41:57
/*
* Map对象,实现Map功能
*
*
* size() 获取Map元素个数
* isEmpty() 判断Map是否为空
* clear() 删除Map所有元素
* put(key, value) 向Map中增加元素(key, value)
* remove(key) 删除指定key的元素,成功返回true,失败返回false
* get(key) 获取指定key的元素值value,失败返回null
* element(index) 获取指定索引的元素(使用element.key,element.value获取key和value),失败返回null
* containsKey(key) 判断Map中是否含有指定key的元素
* containsValue(value) 判断Map中是否含有指定value的元素
* keys() 获取Map中所有key的数组(array)
* values() 获取Map中所有value的数组(array)
*
*/
function Map(){
this.elements = new Array();

//获取Map元素个数
this.size = function() {
return this.elements.length;
},

//判断Map是否为空
this.isEmpty = function() {
return (this.elements.length < 1);
},

//删除Map所有元素
this.clear = function() {
this.elements = new Array();
},

//向Map中增加元素(key, value)
this.put = function(_key, _value) {
if (this.containsKey(_key) == true) {
if(this.containsValue(_value)){
if(this.remove(_key) == true){
this.elements.push( {
key : _key,
value : _value
});
}
}else{
this.elements.push( {
key : _key,
value : _value
});
}
} else {
this.elements.push( {
key : _key,
value : _value
});
}
},

//删除指定key的元素,成功返回true,失败返回false
this.remove = function(_key) {
var bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key){
this.elements.splice(i, 1);
return true;
}
}
}catch(e){
bln = false;
}
return bln;
},

//获取指定key的元素值value,失败返回null
this.get = function(_key) {
try{
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key) {
return this.elements[i].value;
}
}
}catch(e) {
return null;
}
},

//获取指定索引的元素(使用element.key,element.value获取key和value),失败返回null
this.element = function(_index) {
if (_index < 0 || _index >= this.elements.length){
return null;
}
return this.elements[_index];
},

//判断Map中是否含有指定key的元素
this.containsKey = function(_key) {
var bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].key == _key){
bln = true;
}
}
}catch(e) {
bln = false;
}
return bln;
},

//判断Map中是否含有指定value的元素
this.containsValue = function(_value) {
var bln = false;
try {
for (i = 0; i < this.elements.length; i++) {
if (this.elements[i].value == _value){
bln = true;
}
}
}catch(e) {
bln = false;
}
return bln;
},

//获取Map中所有key的数组(array)
this.keys = function() {
var arr = new Array();
for (i = 0; i < this.elements.length; i++) {
arr.push(this.elements[i].key);
}
return arr;
},

//获取Map中所有value的数组(array)
this.values = function() {
var arr = new Array();
for (i = 0; i < this.elements.length; i++) {
arr.push(this.elements[i].value);
}
return arr;
};
}
...全文
11919 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
huazhuaz 2011-07-01
  • 打赏
  • 举报
回复
有用,看过别人代码有!终于可以研究下了!
aborsun 2011-07-01
  • 打赏
  • 举报
回复
map
里面的key可以放汉字吗,如果直接用Object的话,key必须是英文的吧。
esena 2010-11-26
  • 打赏
  • 举报
回复
这样折腾有点自找不自在,个人感觉
痞子虫 2010-11-25
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 theforever 的回复:]

分享是好事。即便有不足,大家讨论改进也是好事情。多些这样的帖子,CSDN的质量才能上去。
[/Quote]

同意这个观点
knightzhuwei 2010-11-25
  • 打赏
  • 举报
回复
楼主是来炫耀下他写的map类
hch126163 2010-11-25
  • 打赏
  • 举报
回复
楼主想说什么呢
猿敲月下码 2010-11-25
  • 打赏
  • 举报
回复
一些地方还可以优化下,为什么不直接用json呢

var Map = {};
Map.key = value;
  • 打赏
  • 举报
回复
分享是好事。即便有不足,大家讨论改进也是好事情。多些这样的帖子,CSDN的质量才能上去。
ahopedog 2010-11-24
  • 打赏
  • 举报
回复
为什么不直接用Object,或用Object作为存放元素的容器。难道Object[key]的访问比Array慢不成?

put: Object[key] = value
remove: delete Object[key]
get: return Object[key]
...
zhengb302 2010-11-24
  • 打赏
  • 举报
回复
在哪看過啊……

87,997

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧