js中MAP集合的构造
2015-11-11 09:39
701 查看
/*
* MAP构造
*/
var Map = function() {
this.keys = new Array();
this.data = new Object();
this.put = function(key, val) {
if (this.data[key] == null) {
this.keys.push(key);
}
this.data[key] = val;
};
this.get = function(key) {
return this.data[key];
};
this.remove = function(key) {
this.keys.remove(key);
this.data[key] = null;
};
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);
}
};
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]
}
}
};
this.isEmpty = function() {
return this.keys.length == 0;
};
this.clear = function() {
this.keys = [];
this.data = {};
}
this.size = function() {
return this.keys.length;
};
this.toString = function() {
var s = "{";
for (var i = 0; i < this.keys.length; i++, s += ",") {
var k = this.keys[i];
s += k + ":" + this.data[k];
}
s += "}";
return s;
};
}
* MAP构造
*/
var Map = function() {
this.keys = new Array();
this.data = new Object();
this.put = function(key, val) {
if (this.data[key] == null) {
this.keys.push(key);
}
this.data[key] = val;
};
this.get = function(key) {
return this.data[key];
};
this.remove = function(key) {
this.keys.remove(key);
this.data[key] = null;
};
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);
}
};
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]
}
}
};
this.isEmpty = function() {
return this.keys.length == 0;
};
this.clear = function() {
this.keys = [];
this.data = {};
}
this.size = function() {
return this.keys.length;
};
this.toString = function() {
var s = "{";
for (var i = 0; i < this.keys.length; i++, s += ",") {
var k = this.keys[i];
s += k + ":" + this.data[k];
}
s += "}";
return s;
};
}
相关文章推荐
- 原生JS判断手机还是电脑登陆
- JavaScript中清空数组的三种方式
- JS中数组的操作
- 轻松实现javascript数据双向绑定
- extjs 4.2 学习笔记(一) 从“Hello World”开始
- js 去掉字符串前后空格
- 详解 javascript中offsetleft属性的用法
- [Javascript] Intro to the Web Audio API
- 【JavaScript知识点十】javascript DOM基本操作
- 详解 javascript中offsetleft属性的用法
- 轻松实现javascript数据双向绑定
- js clearInterval()方法的定义和用法
- js window对象属性和方法相关资料整理
- 详解javascript遍历方式
- js文字横向滚动特效
- 九种原生js动画效果
- javascript图片滑动效果实现
- JavaScript 各种遍历方式详解,有你不知道的黑科技
- 关于AFN 解析不标准的json格式问题
- JavaScript数组对象的声明与使用