JS hashMap实例详解


Posted in Javascript onMay 26, 2016

Hashmap是一种非常常用的、应用广泛的数据类型。本文通过实例代码给大家介绍js hashMap的相关知识,具体代码内容如下所示:

/**
* 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的元素 
* values() 获取MAP中所有VALUE的数组(ARRAY) 
* keys() 获取MAP中所有KEY的数组(ARRAY) 
* 
* 例子: 
* var map = new Map(); 
* 
* map.put("key", "value"); 
* var val = map.get("key") 
* …… 
* 
*/
function hashmap() {
/**
* 存放数据
*/
this.data = new Object();
/**
* 放入一个键值对
* @param {String} key
* @param {Object} value
*/
this.put = function(key, value) 
{
this.data[key] = value;
};
/**
* 获取某键对应的值
* @param {String} key
* @return {Object} value
*/
this.get = function(key) 
{
return this.containsKey(key)?this.data[key]:null; 
};
/**
* 删除一个键值对
* @param {String} key
*/
this.remove = function(key) 
{
delete this.data[key];
};
/**
* 遍历Map,执行处理函数
* 
* @param {Function} 回调函数 function(key,value,index){..}
*/
this.each = function(fn){
if(typeof fn != 'function')
{
return;
}
var len = this.data.length;
for(var i=;i<len;i++)
{
var k = this.data[i];
fn(k,this.data[k],i);
}
};
/**
* 获取键值数组(类似Java的entrySet())
* @return 键值对象{key,value}的数组
*/
this.entrys = function() 
{
var len = this.data.length;
var entrys = new Array(len);
for (var i = ; i < len; i++) {
entrys[i] = {
key : i,
value : this.data[i]
};
}
return entrys;
};
/**
* 判断Map是否为空
*/
this.isEmpty = function() 
{
return this.data.length == ;
};
/**
* 获取键值对数量
*/
this.size = function()
{
return this.data.length;
};
/**
* 重写toString ,装成JSON格式
*/
this.toString = function()
{
var s = "[";
for(var i=;i<this.data.length;i++,s+=','){
var k = this.data[i];
s += "{'id':'" + k+"','value':'"+this.data[k]+"'}";
}
s=s.substring(, s.length-);
if(s!=""){
s+="]";
}
return s;
};
/**
* 输出Value的值
*/
this.values = function (){
var _values= new Array(); 
for(var key in this.data)
{ 
_values.push(this.data[key]); 
} 
return _values; 
};
/**
* 获取keys
*/
this.keySet = function (){
var _keys = new Array(); 
for(var key in this.data)
{ 
_keys.push(key); 
} 
return _keys; 
};
/**
* 判断MAP中是否含有指定KEY的元素 
*/
this.containsKey = function(_key)
{ 
return (_key in this.data); 
}; 
/** 
* 清空Map 
*/ 
this.clear = function(){ 
this.data.length = ;
this.data = new Object();
}; 
}

以上所述是小编给大家介绍的js hashMap实例详解的相关知识,希望对大家有所帮助!

Javascript 相关文章推荐
Prototype最新版(1.5 rc2)使用指南(1)
Jan 10 Javascript
jQuery timers计时器简单应用说明
Oct 28 Javascript
Javascript 中的 call 和 apply使用介绍
Feb 22 Javascript
js简单的表格添加行和删除行操作示例
Mar 31 Javascript
详解javascript传统方法实现异步校验
Jan 22 Javascript
JavaScript实现获取某个元素相邻兄弟节点的prev与next方法
Jan 25 Javascript
js实现简单的省市县三级联动效果实例
Feb 18 Javascript
JavaScript SHA-256加密算法详细代码
Oct 06 Javascript
JS实现二叉查找树的建立以及一些遍历方法实现
Apr 17 Javascript
详解webpack异步加载业务模块
Jun 23 Javascript
AngularJS实现进度条功能示例
Jul 05 Javascript
用ES6的class模仿Vue写一个双向绑定的示例代码
Apr 20 Javascript
jQuery验证插件validate使用方法详解
Sep 13 #Javascript
动态加载js、css的实例代码
May 26 #Javascript
基于JS实现textarea中获取动态剩余字数的方法
May 25 #Javascript
js将json格式的对象拼接成复杂的url参数方法
May 25 #Javascript
使用jquery获取url以及jquery获取url参数的实现方法
May 25 #Javascript
jquery分隔Url的param方法(推荐)
May 25 #Javascript
sso跨域写cookie的一段js脚本(推荐)
May 25 #Javascript
You might like
用PHP制作静态网站的模板框架(一)
2006/10/09 PHP
php object转数组示例
2014/01/15 PHP
PHP图片裁剪函数(保持图像不变形)
2014/05/04 PHP
PHP将字符串首字母大小写转换的实例
2017/01/21 PHP
PHP依赖注入原理与用法分析
2018/08/21 PHP
PHP中rename()函数的妙用讲解
2019/02/28 PHP
广告代码静态化js通用函数
2007/05/09 Javascript
jQuery load方法用法集锦
2011/12/06 Javascript
ASP.NET中AJAX 调用实例代码
2012/05/03 Javascript
jquery的flexigrid无法显示数据提示获取到数据
2013/07/19 Javascript
js+div实现文字滚动和图片切换效果代码
2015/08/27 Javascript
使用jQuery或者原生js实现鼠标滚动加载页面新数据
2016/03/06 Javascript
jQuery animate easing使用方法图文详解
2016/06/17 Javascript
jQuery实现的模拟弹出窗口功能示例
2016/11/24 Javascript
Bootstrap导航条可点击和鼠标悬停显示下拉菜单
2016/11/25 Javascript
利用JQuery阻止事件冒泡
2016/12/01 Javascript
微信小程序 表单Form实例详解(附源码)
2016/12/22 Javascript
详解Vue中使用v-for语句抛出错误的解决方案
2017/05/04 Javascript
webpack学习教程之publicPath路径问题详解
2017/06/17 Javascript
Angular2 http jsonp的实例详解
2017/08/31 Javascript
详解50行代码,Node爬虫练手项目
2019/04/22 Javascript
ES6的解构赋值实例详解
2019/05/06 Javascript
bootstrap table插件动态加载表头
2019/07/19 Javascript
Vue实现商品飞入购物车效果(电商项目)
2019/11/26 Javascript
Vue+elementUI实现多图片上传与回显功能(含回显后继续上传或删除)
2020/03/23 Javascript
vue打开新窗口并实现传参的图文实例
2021/03/04 Vue.js
Python中的exec、eval使用实例
2014/09/23 Python
Python使用正则匹配实现抓图代码分享
2015/04/02 Python
python运行时强制刷新缓冲区的方法
2019/01/14 Python
联想英国官网:Lenovo英国
2019/07/17 全球购物
中国制造网:Made-in-China.com
2019/10/25 全球购物
法学专业自我鉴定
2014/02/05 职场文书
初一新生军训方案
2014/05/22 职场文书
领导班子整改方案和个人整改措施
2014/10/25 职场文书
2014酒店客房部工作总结
2014/12/16 职场文书
2016年学校“3.12”植树节活动总结
2016/03/16 职场文书