js 操作map对象

/*
* 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;
	};
}

转载于:https://my.oschina.net/whp/blog/92917

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值