服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

javascript实现的java里的map对象


  一直想做一个自己的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++){
  if (this.elements[i].key==_key){
  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++){
  if (this.elements[i].key==_key){
  bln=true;
  }
  }
  }catch(e){
  bln=false;
  }
  return bln;
  }
  
  this.get=function(_key){
  try{
  for (i=0;i<this.elements.length;i++){
  if (this.elements[i].key==_key){
  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);
  }
  }

扫描关注微信公众号