javascript中的map

function struct(key, value){
   this.key = key;
   this.value = value;
}

function put(key, value){
 
 // for (var i = 0; i < this.map.length; i++)
 // {
    //if ( this.map[i].key === key )
    //{
    //  this.map[i].value = value;
    //  return;
    //}
//  }
   this.removeKey(key);
   this.map[this.map.length] = new struct(key, value);
}
function putUnique(key, value){
 for (var i = 0; i < this.map.length; i++) {
     if ( this.map[i].key === key ) {
        this.map[i].value = value;
        return;
     }
   }
   this.map[this.map.length] = new struct(key, value);
}

function getFirstKey(){
 if(this.map) {
     return this.map[0].key;
   } else {
    return 0;
   }
}

function getValue(i){
 
    return  this.map[i].value ;
}

function get(key)
{
 for (var i = 0; i < this.map.length; i++) {
  if ( this.map[i].key === key ) {
   return this.map[i].value;
     }
 }
 return null;
}

function removeKey(key)
{
   var v;
   for (var i = 0; i < this.map.length; i++) {
     v = this.map.pop();  //pop() 移除数组中的最后一个元素并返回该元素;
  if ( v.key === key )
   continue;
     
  this.map.unshift(v);  //unshift() 将指定的元素插入数组开始位置并返回该数组
 }
}

function getCount(){
   return this.map.length;
}

function isEmpty(){
  return this.map.length <= 0;
}

function removeAll(){
 var v;
    for (var i = 0; i < this.map.length; i++)
    {
  v = this.map.pop();
  removeKey(v.key);      
    }
}

function getAllKey() {
 var keyArr = new Array();
 if (this.map) {
  for (i=0; i<this.map.length; i++) {
   keyArr[i] = this.map[i].key;
  }
   }
 return keyArr;
}

function Mapping() {
   this.map = new Array();

   this.get = get;
  this.put = put;
 this.putUnique = putUnique;
 this.removeKey = removeKey;
 this.getCount = getCount;
 this.isEmpty = isEmpty;
 //this.removeAll=removeAll;
 this.getFirstKey=getFirstKey;
 this.getValue=getValue;
 this.getAllKey = getAllKey;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值