- Array.prototype.remove = function(s) {
- for (var i = 0; i < this.length; i++) {
- if (s == this[i])
- this.splice(i, 1);
- }
- }
- /**
- * Simple Map
- *
- *
- * var m = new Map();
- * m.put('key','value');
- * ...
- * var s = "";
- * m.each(function(key,value,index){
- * s += index+":"+ key+"="+value+"/n";
- * });
- * alert(s);
- *
- * @author dewitt
- * @date 2008-05-24
- */
- function Map() {
- /** 存放键的数组(遍历用到) */
- this.keys = new Array();
- /** 存放数据 */
- this.data = new Object();
- /**
- * 放入一个键值对
- * @param {String} key
- * @param {Object} value
- */
- this.put = function(key, value) {
- if(this.data[key] == null){
- this.keys.push(key);
- }
- this.data[key] = value;
- };
- /**
- * 获取某键对应的值
- * @param {String} key
- * @return {Object} value
- */
- this.get = function(key) {
- return this.data[key];
- };
- /**
- * 删除一个键值对
- * @param {String} key
- */
- this.remove = function(key) {
- this.keys.remove(key);
- this.data[key] = null;
- };
- /**
- * 遍历Map,执行处理函数
- *
- * @param {Function} 回调函数 function(key,value,index){..}
- */
- this.each = function(fn){
- if(typeof fn != 'function'){
- return;
- }
- var len = this.keys.length;
- for(var i=0;i<len;i++){
- var k = this.keys[i];
- fn(k,this.data[k],i);
- }
- };
- /**
- * 获取键值数组(类似Java的entrySet())
- * @return 键值对象{key,value}的数组
- */
- this.entrys = function() {
- var len = this.keys.length;
- var entrys = new Array(len);
- for (var i = 0; i < len; i++) {
- entrys[i] = {
- key : this.keys[i],
- value : this.data[i]
- };
- }
- return entrys;
- };
- /**
- * 判断Map是否为空
- */
- this.isEmpty = function() {
- return this.keys.length == 0;
- };
- /**
- * 获取键值对数量
- */
- this.size = function(){
- return this.keys.length;
- };
- /**
- * 重写toString
- */
- this.toString = function(){
- var s = "{";
- for(var i=0;i<this.keys.length;i++,s+=','){
- var k = this.keys[i];
- s += k+"="+this.data[k];
- }
- s+="}";
- return s;
- };
- }
- function testMap(){
- var m = new Map();
- m.put('key1','Comtop');
- m.put('key2','南方电网');
- m.put('key3','景新花园');
- alert("init:"+m);
- m.put('key1','康拓普');
- alert("set key1:"+m);
- m.remove("key2");
- alert("remove key2: "+m);
- var s ="";
- m.each(function(key,value,index){
- s += index+":"+ key+"="+value+"/n";
- });
- alert(s);
- }
html代码:
- <html>
- <head>
- <title>Test Map</title>
- <mce:script language="javascript" src="map.js" mce_src="map.js"><!--
- // --></mce:script>
- </head>
- <body>
- <input type="button" value="test" onclick="testMap()">
- </body>
- </html>
相关推荐
jsMap是一款基于JavaScript开发的矢量地图插件,专为Web应用程序设计,提供了一种高效、可定制的方式来展示地理信息。它使用JSON数据格式来存储和处理地图信息,这使得地图数据的传输和渲染更加轻量化,同时也方便了...
js Map对象封装 和 java 的使用方法一样.
js map js map js map js map js map js map
JavaScript中的Map数据结构是ES6引入的一种新的数据存储方式,它与传统的Object对象有显著区别。Map对象主要用于保存键值对,其特点是键可以是任意数据类型,而不仅仅是字符串或Symbol,这使得Map在处理非字符串键时...
javascript 模拟 java中的 List,Map js文件为 js/utils.js IE6.0 测试通过 <br>List: add(var obj) //添加一个元素 remove(var index) //删除一个元素 get(var index) //获取一个元素 remove...
javascript Map原型,对象,实现javascript中的Map数据类型功能
JavaScript中的Map对象是一种数据结构,它允许我们存储键值对,并且键可以是任何类型,而不仅仅是字符串。Map对象在JavaScript ES6版本中被引入,为处理复杂的数据关联提供了更强大的工具,尤其对于那些需要使用非...
JavaScript中的`map()`方法是数组的一个非常重要的方法,它用于创建一个新的数组,新数组中的元素是通过调用原数组中的每个元素上的一个指定函数(即`callback`函数)得到的。这种方法不会改变原数组,而是返回一个...
**JavaScript Map对象详解与实践应用** 在JavaScript的世界里,`Map`对象是一个强大的数据结构,它允许我们存储键值对,且键可以是任意类型,而不仅仅是字符串。这与原生的`Object`有着本质的区别,`Object`的键...
在JavaScript的世界里,`Map`对象是一个非常重要的数据结构,它允许我们存储键值对,其中键可以是任何类型的...在阅读`MapUtil.js`源码时,可以关注这些方法的实现细节,理解它们如何优化和扩展了原生`Map`对象的能力。
javascript map类。类中有相应demo,在javascript中实现Map的一个类,包括map中对应的一些数据结构相关算法。
### JavaScript中的Map应用 在JavaScript中,`Map`对象是一种内置的数据结构,它保存键值对,并且可以按插入顺序记住元素。与普通的JavaScript对象不同的是,`Map`的键可以是任何类型的值(不仅仅是字符串或符号)...
JS map & set 笔记
JavaScript中的Map对象是ES6引入的一种新的数据结构,它提供了键值对的存储方式,与对象类似但有显著区别。Map的主要优势在于键可以是任意类型,而不仅仅是字符串,这使得它在处理复杂数据结构时非常有用。在本文中...
百度地图MAP JS是百度地图提供的JavaScript库,它允许开发者在网页上集成百度地图功能,实现地图的显示、标注、路线规划等多样化操作。这个库基于JavaScript语言,能够轻松地与HTML和CSS结合,为网页增添动态和交互...
对Map的key和value进行排序 对Map的key和value进行排序是Java编程中非常重要的一部分。Map是Java集合框架中的一种数据结构,用于存储键值对。然而,在实际应用中,我们经常需要对Map中的key或value进行排序,以满足...
在提供的描述中,“JS CSS code map of the classic instance of the hyperlink”暗示了这个实例是关于如何利用JavaScript和CSS结合,创建一个带有超链接功能的地图。 JavaScript(JS)在这里起到了关键作用,它...
在JavaScript中,`Map`是一种内置的数据结构,用于存储键值对。相比于对象,`Map`的优势在于它可以使用任何类型的值作为键,包括对象。在本文中,我们将深入探讨一种高性能的JavaScript `Map`实现,它基于JSON,具有...
使用js实现map工具类
* size() 获取MAP元素个数 * isEmpty() 判断MAP是否为空 * clear() 删除MAP所有元素 * put(key, value) 向MAP中增加元素(key, value) * remove(key) 删除指定KEY的元素,成功返回True,失败返回False * ...