手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JavaScript中创建字典对象(dictionary)实例
JavaScript中创建字典对象(dictionary)实例
摘要:对于JavaScript来说,其自身的Array对象仅仅是个数组,无法提供通过关键字来获取保存的数据,jQuery源码中提供了一种非常好的方...

对于JavaScript来说,其自身的Array对象仅仅是个数组,无法提供通过关键字来获取保存的数据,jQuery源码中提供了一种非常好的方式来解决这个问题,先看一下源码:

复制代码 代码如下:

function createCache() {

var keys = [];

function cache(key, value) {

// Use (key + " ") to avoid collision with native prototype

// properties (see Issue #157)

if (keys.push(key += " ") > Expr.cacheLength) {

// Only keep the most recent entries

delete cache[keys.shift()];

}

return (cache[key] = value);

}

return cache;

}

上述源码是创建一个编译结果的缓存,代码调用方式如下:

复制代码 代码如下:

var codecache = createCache();

源码中,keys用来保存键,而cache对象用来保存键值对,并通过全局变量Expr.cacheLength控制键的最大数量,若超过该数量,则自动删除第一个键及键值对。

本代码利用了闭包的结构,使外部代码无法访问到keys变量,这样就能确保keys变量的安全性。当然,由于JavaScript语句的特点,外部代码还是可以通过修改cache属性使键与键值对不匹配。不过,只要不故意恶搞,这本身应该也没有太大的关系。

当然,它也不能宣誓一个完善的dictionary对象,因为其未提供主键重复的判断等关键功能,有兴趣的朋友们可以完善它。

【JavaScript中创建字典对象(dictionary)实例】相关文章:

JavaScript深度复制(deep clone)的实现方法

Javascript中prototype属性实现给内置对象添加新的方法

javaScript中push函数用法实例分析

Javascript中For In语句用法实例

javaScript中with函数用法实例分析

Javascript中With语句用法实例

Javascript实现div的toggle效果实例分析

Javascript进制转换实例

JavaScript中操作字符串之localeCompare()方法的使用

JavaScript中的异常处理方法介绍

精品推荐
分类导航