JavaScript实现map

简介: //定义map function Map() { this.container = {};}//将key-value放入map中 Map.prototype.
//定义map     
function Map() {
    this.container = {};
}
//将key-value放入map中     
Map.prototype.put = function(key, value) {
    try {
        if (key != null && key != "")
            this.container[key] = value;
    } catch (e) {
        return e;
    }
};

//根据key从map中取出对应的value     
Map.prototype.get = function(key) {
    try {
        return this.container[key];
    } catch (e) {
        return e;
    }
};

//判断map中是否包含指定的key     
Map.prototype.containsKey = function(key) {
    try {
        for ( var p in this.container) {
            if (p == key)
                return true;
        }
        return false;

    } catch (e) {
        return e;
    }

}

//判断map中是否包含指定的value     
Map.prototype.containsValue = function(value) {
    try {
        for ( var p in this.container) {
            if (this.container[p] === value)
                return true;
        }
        return false;

    } catch (e) {
        return e;
    }
};

//删除map中指定的key     
Map.prototype.remove = function(key) {
    try {
        delete this.container[key];
    } catch (e) {
        return e;
    }
};

//清空map     
Map.prototype.clear = function() {
    try {
        delete this.container;
        this.container = {};

    } catch (e) {
        return e;
    }
};

//判断map是否为空     
Map.prototype.isEmpty = function() {

    if (this.keySet().length == 0)
        return true;
    else
        return false;
};

//获取map的大小     
Map.prototype.size = function() {

    return this.keySet().length;
}

//返回map中的key值数组     
Map.prototype.keySet = function() {
    var keys = new Array();
    for ( var p in this.container) {
        keys.push(p);
    }

    return keys;
}

//返回map中的values值数组     
Map.prototype.values = function() {
    var valuesArray = new Array();
    var keys = this.keySet();
    for (var i = 0; i < keys.length; i++) {
        valuesArray.push(this.container[keys[i]]);
    }
    return valuesArray;
}

//返回 map 中的 entrySet 对象
Map.prototype.entrySet = function() {
    var array = new Array();
    var keys = this.keySet();
    for (var i = 0; i < keys.length; i++) {
        array.push(keys[i],this.container[keys[i]]);
    }
    return array;
}

//返回 map 中的 value值的和(当值是 Nunmber 类型时有效)
Map.prototype.sumValues = function() {
    var values = this.values();
    var result = 0;
    for (var i = 0; i < values.length; i++) {
        result += Number(values[i]);
    }
    return result;
}

///计算两个整数的百分比值 
function toPercent(num, total){
    num = parseFloat(num); 
    total = parseFloat(total); 
    if (isNaN(num) || isNaN(total)) { 
        return "0"; 
    } 
    return total <= 0 ? "0%" : (Math.round(num / total * 10000) / 100.00 + "%"); 
//    return (Math.round(this * 10000)/100).toFixed(2) + '%';
}
目录
相关文章
|
6月前
|
JavaScript 前端开发 API
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
存储 JavaScript 前端开发
js中map属性
js中map属性
114 1
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。
169 3
|
JavaScript 前端开发
JavaScript Array map() 方法
JavaScript Array map() 方法
|
存储 JavaScript 前端开发
js的map和set |21
js的map和set |21
|
JavaScript 前端开发
js map和reduce
js map和reduce
|
11月前
|
存储 JavaScript 前端开发
js中map属性
js中map属性
189 0
|
11月前
|
前端开发 JavaScript 索引
JavaScript 数组常用高阶函数总结,包括插入,删除,更新,反转,排序等,如map、splice等
JavaScript数组的常用高阶函数,包括遍历、插入、删除、更新、反转和排序等操作,如map、splice、push、pop、reverse等。
308 0
|
JavaScript 前端开发 索引
JS中常用的数组迭代方法(filter,forEach,map,every,some,find,findIndex)
这段代码和说明介绍了JavaScript中数组的一些常用方法。函数接收三个参数:`item`(数组项的值)、`index`(项的位置,可选)和`array`(数组本身,可选)。示例展示了如何使用`filter()`过滤非空项、`forEach()`遍历数组、`map()`处理并返回新数组、`every()`检查所有元素是否满足条件、`some()`检查是否存在满足条件的元素、`find()`获取首个符合条件的元素值以及`findIndex()`获取其索引位置。这些方法都不会修改原数组。
297 0
JS中常用的数组迭代方法(filter,forEach,map,every,some,find,findIndex)