继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

自定义页面hashmap 方便调用

英明神武的牛
关注TA
已关注
手记 317
粉丝 30
获赞 175

因为页面一些功能问题,经常要用到类似于map的集合,存取数据。所以就定义一个方便使用


新建一个js文件,把如下代码copy到文件中:

function HashMap() {

/** Map 大小 * */

var size = 0;

/** 对象 * */

var entry = new Object();


/** 存 * */

this.put = function(key, value) {

if (!this.containsKey(key)) {

size++;

}

entry[key] = value;

}


/** 取 * */

this.get = function(key) {

return this.containsKey(key) ? entry[key] : null;

}


/** 删除 * */

this.remove = function(key) {

if (this.containsKey(key) && (delete entry[key])) {

size--;

}

}


/** 是否包含 Key * */

this.containsKey = function(key) {

return (key in entry);

}


/** 是否包含 Value * */

this.containsValue = function(value) {

for ( var prop in entry) {

if (entry[prop] == value) {

return true;

}

}

return false;

}


/** 所有 Value * */

this.values = function() {

var values = new Array();

for ( var prop in entry) {

values.push(entry[prop]);

}

return values;

}


/** 所有 Key * */

this.keys = function() {

var keys = new Array();

for ( var prop in entry) {

keys.push(prop);

}

return keys;

}


/** Map Size * */

this.size = function() {

return size;

}


/* 清空 */

this.clear = function() {

size = 0;

entry = new Object();

}

}


//自定义对象

function MyObject(name)

{

    this.name = name;

    this.toString = function ()

    {

        return this.name;

    }

}



用法如下:

实例对象

 var map = new HashMap();

存:key value键值对

map.put($(this).text(),$(this).val());


取:

var getValue=map.get(key);


取长度:map.size();


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP