字典是一種以「鍵–值」對形式儲存資料的資料結構。就像電話薄裡的名字和號碼一樣。 JavaScript的Object類別就是以字典的形式設計的。
字典類別(Dictionary)基於Object。在《資料結構與演算法JavaScript描述》書中「字典」採用了陣列儲存數據,不僅讓閱讀者很難理解,也沒有實現便利性,反而其中的程式碼邏輯是錯誤的,不能按照設計的方式正確輸出結果! ! !
/** * 构造函数 * 基于对象存储数据 * @constructor */function Dictionary(){ this.datastore = new Object(); } Dictionary.prototype = { /* 修正constructor */ constructor: Dictionary, /* 统计个数 */ size: function(){ return Object.keys(this.datastore).length; }, /* 添加元素,给数组添加属性 */ add: function(key, value){ this.datastore[key] = value; }, /* 查找指定key的元素 */ find: function(key){ return this.datastore[key]; }, /* 移除指定key的元素 */ remove: function(key){ delete this.datastore[key]; }, /* 显示所有的键值对 */ showAll: function(){ for(var key in this.datastore){ console.log(key + ": " + this.find(key)); } } };
測試:
var dic = new Dictionary(); dic.add("name", "ligang"); dic.add("age", 26); dic.find("name"); // "ligang"dic.size(); // 2dic.showAll(); // "name: ligang" "age: 26"dic.remove("age"); dic.size(); // 1dic.showAll(); // "name: ligang"
補充:Object.keys(obj)
傳回一個數組,包含所有(自身)可枚舉屬性。請檢視-JavaScript物件、函數(你不知道的JavaScript)
為字典排序,可以轉換為某個物件屬性排序。所以我們可以藉助Object.keys()
/* 排序 */Dictionary.prototype.sort = function(){ // 借助数组的默认排序 var keys = Object.keys(this.datastore).sort(); // 新定义字典类 var tempDic = new Dictionary(); for(var i = 0, len = keys.length; i < len; i++){ var key = keys[i]; tempDic.add(key, this.find(key)); } return tempDic; };
測試:
var dictionary = new Dictionary(); dictionary.add("b", 2); dictionary.add("a", 1); dictionary.add("c", 3); dictionary.showAll(); // "b: 2" "a: 1" "c: 3"dictionary.sort().showAll(); // "a: 2" "b: 1" "c: 3"
總結:上述字典類別不允許出現重複的key。對於相同的key,後面的會覆蓋前面的。當然,可以透過修改程式碼實現其他方式。
相關推薦:
#以上是詳解JavaScript資料結構之字典類的詳細內容。更多資訊請關注PHP中文網其他相關文章!