Js实现Map对象的代码

<script type="text/javascript"><!--  

/**
 *  @author: kalogen

 *  @date:  2011-1-8
 *  map对象类,提供了put,get,remove,size,isEmpty等方法
 */
function Map() {
 /**
  * 构造函数
  * @param {} key
  * @param {} value
  */
 var struct = function(key, value) {
  this.key = key;
  this.value = value;
 }
 /**
  * 添加key对应的值,如果key已经存在则直接更新对应的值
  * @param {} key
  * @param {} value
  */
 var put = function(key, value) {
  for (var i = 0; i < this.arr.length; i++) {
   if (this.arr[i].key === key) {
    this.arr[i].value = value;
    return;
   }
  }
  this.arr[this.arr.length] = new struct(key, value);
 }
 /**
  * 获取key对应的值
  * @param {} key
  * @return {}
  */
 var get = function(key) {
  for (var i = 0; i < this.arr.length; i++) {
   if (this.arr[i].key === key) {
    return this.arr[i].value;
   }
  }
  return null;
 }
 /**
  * 移除key对应的值
  * @param {} key
  */
 var remove = function(key) {
  var v;
  for (var i = 0; i < this.arr.length; i++) {
   v = this.arr.pop();
   if (v.key === key) {
    continue;
   }
   this.arr.unshift(v);
  }
 }
 /**
  * 获取map对象的长度
  * @return {}
  */
 var size = function() {
  return this.arr.length;
 }
 /**
  * 判断map对象是否为空
  * @return {}
  */
 var isEmpty = function() {
  return this.arr.length <= 0;
 }
 this.arr = new Array();
 this.get = get;
 this.put = put;
 this.remove = remove;
 this.size = size;
 this.isEmpty = isEmpty;
}

// -->
</script> 

 

<script type="text/javascript"><!--  
 var map = new Map();  
 map.put("re","redhacker");  
 map.put("do","douguoqiang");  
 map.put("gq","dougq");  
 alert("map的大小为:" + map.size())  
 alert("key为re的map中存储的对象为:" + map.get("do"));
 map.remove("re");  
 alert("移除key为re的对象后,获取key为re的map中存储的对象为:" + map.get("do"));  
 alert("map移除一个元素后的大小为:" + map.size());  
 alert("map是否是一个空map:" + map.isEmpty());  
// -->
</script> 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值