国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js 模擬實現類似c#下的hashtable的簡單功能代碼

2019-11-21 00:47:29
字體:
來源:轉載
供稿:網友
如果在c#中,我們只要用hashtable或者dictionary根據key取value的特性,就可以很輕松地實現這個功能了。其實我們稍作處理,js也可以實現類似hashtable的功能。下面總結一下筆者開發中用到的實現方式,貼代碼為主。
1、實現思路:主要就是利用原型(prototype)的hasOwnProperty方法,確定對象中的項是該添加、移除還是取出某個匹配的項等。hasOwnProperty比遍歷數組取值靈巧快速的地方在于:至少從代碼上來看,它是O(1)復雜度的。
2、實現代碼
復制代碼 代碼如下:

// js哈希表
function HashTable() {
this.ObjArr = {};
this.Count = 0;
//添加
this.Add = function(key, value) {
if (this.ObjArr.hasOwnProperty(key)) {
return false; //如果鍵已經存在,不添加
}
else {
this.ObjArr[key] = value;
this.Count++;
return true;
}
}
//是否包含某項
this.Contains = function(key) {
return this.ObjArr.hasOwnProperty(key);
}
//取某一項 其實等價于this.ObjArr[key]
this.GetValue = function(key) {
if (this.Contains(key)) {
return this.ObjArr[key];
}
else {
throw Error("Hashtable not cotains the key: " + String(key)); //腳本錯誤
//return;
}
}
//移除
this.Remove = function(key) {
if (this.Contains(key)) {
delete this.ObjArr[key];
this.Count--;
}
}
//清空
this.Clear = function() {
this.ObjArr = {}; this.Count = 0;
}
}

3、測試代碼
代碼
復制代碼 代碼如下:

//員工
function employee(id, userName) {
this.id = id;
this.userName = userName;
}
function test() {
var ht = new HashTable();
var tmpEmployee = null;
for (var i = 1; i < 6; i++) {
tmpEmployee = new employee(i, "Employee_" + i);
ht.Add(i, tmpEmployee);
}
for (var i = 1; i <= ht.Count; i++) {
alert(ht.GetValue(i).userName); //其實等價于ht.ObjArr[i].userName
//alert(ht.ObjArr[i].userName);
}
ht.Remove(1);
alert(ht.Contains(1)); //false
alert(ht.Contains(2)); //true
//alert(ht.GetValue(1)); //異常
var result = ht.GetValue(2);
if (result != null) {
alert("Employee Id:" + result.id + ";UserName:" + result.userName);
}
ht.Add(2, "這一個key已經存在!"); //Add無效
//ht.Clear(); //清空
alert(ht.Count);
}

調用的時候很簡單,只要new一個hashtable對象,常見的功能就都有了。是不是很簡單?Enjoy it。
小結:原型鏈(prototype鏈)和作用域鏈是js的兩個最核心的部分。學懂并悟透它們,許多復雜問題都會迎刃而解;好好利用它們的特性,我們可以輕松實現非常靈活高效的功能。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 资中县| 明水县| 湖南省| 梧州市| 连江县| 健康| 原阳县| 虎林市| 香格里拉县| 台北县| 通海县| 轮台县| 侯马市| 阳春市| 仁寿县| 昆山市| 浑源县| 松桃| 宁阳县| 漠河县| 桑日县| 安陆市| 文水县| 蓬溪县| 和政县| 顺昌县| 三穗县| 林芝县| 康乐县| 铜川市| 苍梧县| 万年县| 桂东县| 文昌市| 镇雄县| 桦甸市| 东乡| 赞皇县| 江安县| 乐亭县| 岑溪市|