js實現HashTable(哈希表)的實例分析
更新時間:2016年11月21日 15:52:59 作者:逆心
本文詳細介紹javascript哈希表的實例分析及用法。下面就跟小編一起來學習下吧
一、javascript哈希表簡介
javascript里面是沒有哈希表的,一直在java,C#中有時候用到了這一種數據結構,javascript里面若沒有,感覺非常不順手。細細看來,其實javascript的object的屬性其實與哈希表非常類似。
如:
var person = {}; person["name"] = "關羽";
我們只需要在其基礎上再封裝一些HashTable的函數,就能夠得到一個精簡版的哈希表。
加入函數如下:
函數名 | 說明 | 返回值 |
add(key,value) | 添加項 | 無 |
getValue(key) | 根據key取值 | object |
remove(key) | 根據key刪除一項 | 無 |
containsKey(key) | 是否包含某個key | bool |
containsValue(value) | 是否包含某個值 | bool |
getValues() | 獲取所有的值的數組 | array |
getKeys() | 獲取所有的key的數組 | array |
getSize() | 獲取項總數 | int |
clear() | 清空哈希表 | 無 |
二、代碼實現
其具體的實現可以查看代碼,都不算很復雜的東西。
function HashTable() { var size = 0; var entry = new Object(); this.add = function (key, value) { if (!this.containsKey(key)) { size++; } entry[key] = value; } this.getValue = function (key) { return this.containsKey(key) ? entry[key] : null; } this.remove = function (key) { if (this.containsKey(key) && (delete entry[key])) { size--; } } this.containsKey = function (key) { return (key in entry); } this.containsValue = function (value) { for (var prop in entry) { if (entry[prop] == value) { return true; } } return false; } this.getValues = function () { var values = new Array(); for (var prop in entry) { values.push(entry[prop]); } return values; } this.getKeys = function () { var keys = new Array(); for (var prop in entry) { keys.push(prop); } return keys; } this.getSize = function () { return size; } this.clear = function () { size = 0; entry = new Object(); } }
簡單使用示例:
var manHT = new HashTable(); manHT.add("p1","劉備"); manHT.add("p2","關羽"); $("#div1").text(manHT.getValue("p1"));
以上是本文的全部內容,希望對大家有所幫助!
相關文章
JS removeAttribute()方法實現刪除元素的某個屬性
這篇文章主要介紹了JS removeAttribute()方法實現刪除元素的某個屬性,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01利用JS解決ie6不支持max-width,max-height問題的方法
本篇文章主要介紹了利用JS解決ie6不支持max-width,max-height問題的方法。需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01JavaScript 監(jiān)聽textarea中按鍵事件
不同的瀏覽器中的事件監(jiān)聽機制是不同的,以onKeyPress事件為例。2009-10-10