站内搜索: 请输入搜索关键词

当前页面: 开发资料首页Javascript 专题javascript 实现的类似于java里的Map对象

javascript 实现的类似于java里的Map对象

摘要: javascript 实现的类似于java里的Map对象
<textarea readonly style="border:none;font-family:Courier New;line-height:150%;width:760px;overflow-y:visible">

一直想做一个自己的ajax框架,所以要给自己的javascript要恶补一下。

最近在看javascript权威指南第四版,有10000多页,象字典一样。不过确实够权威的。

javascript的提供的对象比较少,不象java一样,有List,ArrayList,Map,HashMap等各种数据对象。于是就利用javascript的对象技术,封装了一个类似于java里的Map 对象

//自定义的Map 对象

function Map(){
this.elements=new Array();
this.size=function(){
return this.elements.length;
}
this.put=function(_key,_value){
this.elements.push({key:_key,value:_value});
}

this.remove=function(_key){
var bln=false;
try{
for (i=0;i<this.elements.length;i++){
this.elements.splice(i,1);
return true;
}
}
}catch(e){
bln=false;
}
return bln;
}

this.containsKey=function(_key){
var bln=false;
try{
for (i=0;i<this.elements.length;i++){
bln=true;
}
}
}catch(e){
bln=false;
}
return bln;

}

this.get=function(_key){
try{
for (i=0;i<this.elements.length;i++){
return this.elements[i];
}
}
}catch(e){
return null;
}
}

}

//测试Map的调用方法

function testMap(){
var testmap=new Map();
testmap.put("01","michael");
testmap.put("02","michael2");
alert (testmap.size());

var key="02"
if (testmap.containsKey(key)){
var element=testmap.get(key);
alert (element.key+"|"+element.value);
}else{
alert ("不包含"+key);
}

testmap.remove("02");
if (testmap.containsKey(key)){
var element=testmap.get(key);
alert (element.key+"|"+element.value);
}else{
alert ("不包含"+key);
}

}


</textarea>
↑返回目录
前一篇: javascript设计模式交流(一) ——Singleton Pattern
后一篇: Javascript中arguments的用法