Javascript 中类似Map集合的实现键值对

    

    我从网上找了一些资料  如何实现javascript中的map 集合

注明:此代码也是从网上搜集过来的并且将其稍微改进了点,如有雷同请勿喷.

   很感谢 提供基础代码的人.希望看到的人也能将其更加晚上然后共享给大家;

 

进入主题:代码如下

 

 

var Map = function() {
	this.elements = new Array();

	this.size = function() {
		return this.elements.length;
	}

	this.isEmpty = function() {
		return (this.elements.length < 1);
	}

	this.clear = function() {
		this.elements.length = 0;
	}

	this.put = function(_key, _value) {
		this.elements.push( {
			key : _key,
			value : _value
		});
	}

	this.remove = function(_key) {
		try {
			for ( var i = 0; i < this.size(); i++) {

				if (this.elements[i].key == _key)
					this.elements.splice(i, 1);
				return true;
			}
		} catch (e) {
			return false;
		}
		return false;
	}

	this.get = function(_key) {
		
		try {
			for ( var i = 0; i < this.size(); i++) {
				if (this.elements[i].key == _key) {
					var _value = this.elements[i].value;
					return _value;
				}
			}
		} catch (e) {
			return null;
		}
		return null;
	}
	
	this.containsKey=function(_key){
		try {
			for ( var i = 0; i < this.size(); i++) {
				if (this.elements[i].key == _key) {
					return true;
				}
			}
		} catch (e) {
			return false;
		}
		return false;
	}

	
	this.getValues=function(){
		var values=new Array();
		try {
			for ( var i = 0; i < this.size(); i++) {
				values.push(this.elements[i].key);
			}
		} catch (e) {
			alert("Can not get Map Values ! {1}"+e.message);
			return null;
		}
		return values;
	}
	
	this.getKeys=function(){
		var keys=new Array();
		try {
			for ( var i = 0; i < this.size(); i++) {
				keys.push(this.elements[i].values);
			}
		} catch (e) {
			alert("Can not get Map Keys ! {1}"+e.message);
			return null;
		}
		return keys;
	}
	
	this.mapStr=function(){
		return this.elements.toString();
		
	} 
	
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值