js里封装好用的Map对象
1.封装Map
function Map() {
/** 存放键的数组(遍历用到) */
this.keys = new Array();
/** 存放数据 */
this.data = new Object();
/**
* 放入一个键值对
*
* @param {String}
* key
* @param {Object}
* value
*/
this.put = function (key, value) {
if (this.data[key] == null) {
this.keys.push(key);
}
this.data[key] = value;
};
/**
* 获取某键对应的值
*
* @param {String}
* key
* @return {Object} value
*/
this.get = function (key) {
return this.data[key];
};
/**
* 删除一个键值对
*
* @param {String}
* key
*/
this.remove = function (key) {
this.keys.remove(key);
this.data[key] = null;
};
/**
* 遍历Map,执行处理函数
*
* @param {Function}
* 回调函数 function(key,value,index){..}
*/
this.each = function (fn) {
if (typeof fn != 'function') {
return;
}
var len = this.keys.length;
for (var i = 0; i < len; i++) {
var k = this.keys[i];
fn(k, this.data[k], i);
}
};
/**
* 获取键值数组(类似Java的entrySet())
*
* @return 键值对象{key,value}的数组
*/
this.entrys = function () {
var len = this.keys.length;
var entrys = new Array(len);
for (var i = 0; i < len; i++) {
entrys[i] = {
key: this.keys[i],
value: this.data[i]
};
}
return entrys;
};
/**
* 判断Map是否为空
*/
this.isEmpty = function () {
return this.keys.length == 0;
};
/**
* 获取键值对数量
*/
this.size = function () {
return this.keys.length;
};
/**
* 重写toString
*/
this.toString = function () {
var s = "{";
for (var i = 0; i < this.keys.length; i++) {
if (i > 0) {
s += ',';
}
var k = this.keys[i];
s += k + ":" + this.data[k];
}
s += "}";
return s;
};
}
2.使用方法(封装之后的Map用法与java一致)
首先定义一个Map对象
var reJson = new Map();
加入key,value键值对,相当于加入一个Object
reJson.put("key","value");
//根据key获取value
reJson.get("key");
//根据key删除value
reJson.remove("key");
//each循环
each(map,function(i,n){
//循环体
})
3.用于重新组装json
reJson.put("patInHosId",fieldmap["zyh"].val);
reJson.put("createTime",fieldmap["zxsj"].val);
reJson.put("nurseId",fieldmap["hsbh"].val);
reJson.put("nurseName",fieldmap["hsxm"].val);
组装完json后可以直接JSON.stringify(reJson)转成String,传到后台用实体类接收即可。