[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
Web开发
> 详细
js-map模拟
时间:
2017-04-15 23:09:01
阅读:
225
评论:
0
收藏:
0
[点我收藏+]
/*
* 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
Map() {
this
.elements =
new
Array();
//获取MAP元素个数
this
.size =
function
() {
return
this
.elements.length;
}
//判断MAP是否为空
this
.isEmpty =
function
() {
return
(
this
.elements.length < 1);
}
//删除MAP所有元素
this
.clear =
function
() {
this
.elements =
new
Array();
}
//向MAP中增加元素(key, value)
this
.put =
function
(_key, _value) {
this
.elements.push( {
key : _key,
value : _value
});
}
//删除指定KEY的元素,成功返回True,失败返回False
this
.remove =
function
(_key) {
var
bln =
false
;
try
{
for
(i = 0; i <
this
.elements.length; i++) {
if
(
this
.elements[i].key == _key) {
this
.elements.splice(i, 1);
return
true
;
}
}
}
catch
(e) {
bln =
false
;
}
return
bln;
}
//获取指定KEY的元素值VALUE,失败返回NULL
this
.get =
function
(_key) {
try
{
for
(i = 0; i <
this
.elements.length; i++) {
if
(
this
.elements[i].key == _key) {
return
this
.elements[i].value;
}
}
}
catch
(e) {
return
null
;
}
}
//获取指定索引的元素(使用element.key,element.value获取KEY和VALUE),失败返回NULL
this
.element =
function
(_index) {
if
(_index < 0 || _index >=
this
.elements.length) {
return
null
;
}
return
this
.elements[_index];
}
//判断MAP中是否含有指定KEY的元素
this
.containsKey =
function
(_key) {
var bln =
false
;
try
{
for
(i = 0; i <
this
.elements.length; i++) {
if
(
this
.elements[i].key == _key) {
bln =
true
;
}
}
}
catch
(e) {
bln =
false
;
}
return
bln;
}
//判断MAP中是否含有指定VALUE的元素
this
.containsValue =
function
(_value) {
var
bln =
false
;
try
{
for
(i = 0; i <
this
.elements.length; i++) {
if
(
this
.elements[i].value == _value) {
bln =
true
;
}
}
}
catch
(e) {
bln =
false
;
}
return
bln;
}
//获取MAP中所有VALUE的数组(ARRAY)
this
.values =
function
() {
var
arr =
new
Array();
for
(i = 0; i <
this
.elements.length; i++) {
arr.push(
this
.elements[i].value);
}
return
arr;
}
//获取MAP中所有KEY的数组(ARRAY)
this
.keys =
function
() {
var
arr =
new
Array();
for
(i = 0; i <
this
.elements.length; i++) {
arr.push(
this
.elements[i].key);
}
return
arr;
}
}
/*
* 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
Map() {
this
.elements =
new
Array();
//获取MAP元素个数
this
.size =
function
() {
return
this
.elements.length;
}
//判断MAP是否为空
this
.isEmpty =
function
() {
return
(
this
.elements.length < 1);
}
//删除MAP所有元素
this
.clear =
function
() {
this
.elements =
new
Array();
}
//向MAP中增加元素(key, value)
this
.put =
function
(_key, _value) {
this
.elements.push( {
key : _key,
value : _value
});
}
//删除指定KEY的元素,成功返回True,失败返回False
this
.remove =
function
(_key) {
var
bln =
false
;
try
{
for
(i = 0; i <
this
.elements.length; i++) {
if
(
this
.elements[i].key == _key) {
this
.elements.splice(i, 1);
return
true
;
}
}
}
catch
(e) {
bln =
false
;
}
return
bln;
}
//获取指定KEY的元素值VALUE,失败返回NULL
this
.get =
function
(_key) {
try
{
for
(i = 0; i <
this
.elements.length; i++) {
if
(
this
.elements[i].key == _key) {
return
this
.elements[i].value;
}
}
}
catch
(e) {
return
null
;
}
}
//获取指定索引的元素(使用element.key,element.value获取KEY和VALUE),失败返回NULL
this
.element =
function
(_index) {
if
(_index < 0 || _index >=
this
.elements.length) {
return
null
;
}
return
this
.elements[_index];
}
//判断MAP中是否含有指定KEY的元素
this
.containsKey =
function
(_key) {
varbln =
false
;
try
{
for
(i = 0; i <
this
.elements.length; i++) {
if
(
this
.elements[i].key == _key) {
bln =
true
;
}
}
}
catch
(e) {
bln =
false
;
}
return
bln;
}
//判断MAP中是否含有指定VALUE的元素
this
.containsValue =
function
(_value) {
var
bln =
false
;
try
{
for
(i = 0; i <
this
.elements.length; i++) {
if
(
this
.elements[i].value == _value) {
bln =
true
;
}
}
}
catch
(e) {
bln =
false
;
}
return
bln;
}
//获取MAP中所有VALUE的数组(ARRAY)
this
.values =
function
() {
var
arr =
new
Array();
for
(i = 0; i <
this
.elements.length; i++) {
arr.push(
this
.elements[i].value);
}
return
arr;
}
//获取MAP中所有KEY的数组(ARRAY)
this
.keys =
function
() {
var
arr =
new
Array();
for
(i = 0; i <
this
.elements.length; i++) {
arr.push(
this
.elements[i].key);
}
return
arr;
}
}
js-map模拟
原文:http://www.cnblogs.com/zfzf1/p/6715782.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!