您好,登錄后才能下訂單哦!
因為頁面一些功能問題,經常要用到類似于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();
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。