JAVAScript js 模拟JAVA map类 实现put get 等JAVA map类方法

来源:互联网 发布:达芬奇救世主 知乎 编辑:程序博客网 时间:2024/05/22 07:43

注:转载请注明出处!
/** ------------------------public method -------------------------*/
/**
* 为array添加remove方法
*
* @param s
*            移除的数组中的值
* @return
*/
Array.prototype.remove = function(s) {
for ( var i = 0; i < this.length; i++) {
if (s == this[i])
this.splice(i, 1);
}
}
/** ------------------------public method end------------------------- */
/** ------------------------ByteMap start------------------------- */
/**
* 模拟JAVA map 类,put(key,value),get(key),remove(key),isEmpty,..........
*/
function ByteMap() {
/** keys 存放键值 data 存放数据 */
var keys = new Array();
var data = new Object();

/**
* 放入一个键值对
*
* @param key
*            值 String
* @param value
*            键值 object
*/
this.put = function(key, value) {
if (data[key] == null) {
keys.push(key);
}
data[key] = value;
};
/**
* 获得某键位的键值
*
* @param key
*            键 String
*/
this.get = function(key) {
return date[key];
};
/**
* 通过键值删除某键位 key不存在时,返回"-1"
*
* @param key
*            键 String
*/
this.remove = function(key) {
// key不存在时
if (data[key] == null) {
return '-1';
}
keys.remove(key);
data[key] = null;
};
/**
* 遍历函数 执行回调函数fn(key,value,index) 参数非函数时 ruturn "-1"
*
* @param fn
*            回调函数名称 函数参数应为(key,value,index)
*/
this.each = function(fn) {
// 检查是否存在此函数
if (typeof fn != 'function') {
return '-1';
}
for ( var i = 0; i < keys.length; i++) {
fn(keys[i], data[keys[i]], i);
}
};
/**
* 获得键值对应的数组 类似JAVA的entrySet()
*
* @return 键值对象{key,value}的数组
*/
this.entryArray = function() {
var len = keys.length;
var tempArr = new Array(len);
for ( var i = 0; i < len; i++) {
tempArr[i] = {
key : keys[i],
value : data[keys[i]]
};
}
return tempArr;
};
/**
* 返回key键数组 类似于JAVA的ketSet()函数
*
* @return Array
*/
this.keySet = function() {
return keys;
}
/**
* 判断map是否为空
*
* @return 空返回TRUE 不为空返回 FALSE
*/
this.isEmpty = function() {
return keys.length == 0;
};
/**
* 返回map的大小
*/
this.size = function() {
return keys.length;
};
/**
* 重写toString 格式为{key1=value1,key2=value2,....}
*/
this.toString = function() {
var len = keys.length;
var temp = "{";
for ( var i = 0; i < len; i++) {
temp += (keys[i] + "=" + data[keys[i]] + ",");
}
temp += "}";
return temp;
};
/**
* 清空map
*
* @return
*/
this.clear = function() {
for ( var i = keys.length - 1; i >= 0; i--) {
delete data[keys[i]];
keys.pop(i);
}
};
}
/** ------------------------ByteMap test Method start------------------------- */