js的Map对象

function Map(){
    
    this.elements=new Array();
    //获取Map的尺寸
    this.size=function(){
        return elements.length;
    }
    //判断Map是否为空
    this.isEmpty=function(){
        return (elements.length<1);
    }
    //删除Map所有元素
    this.clear=function(){
        elements=new Array();
    }

    this.put = function(_key, _value) {
        this.elements.push( {
            key : _key,
            value : _value
        });
    }
    //删除指定Key的元素,成功返回true否则返回false
    this.remove=function(_key){
        var flag=true;
        try {
            for (var i = 0; i < this.elements.length; i++) {
                if (this.elements[i].key == _key) {
                    this.elements.splice(i, 1);
                    return flag;
                }
            }
            flag=false;
        } catch (e) {
            flag=false;
        }
        return flag;
    }
    //获取指定Key值的value
    this.get=function(_key){
        try {
            for ( var i = 0; i < this.elements.length; i++) {
                if (this.elements[i].key == _key) {
                    return this.elements[i].value;
                }
            }
            return null;
        } catch (e) {
            return null;
        }
    }
    //获取指定的索引元素
    this.element=function(_index){
        if(_index<0||_index>=this.elements.length){
            return null;
        }
        return this.elements[_index];
    }
    //判断Map中是否存在指定的Key值
    this.containsKey=function(_key){
        var flag = false;
        try {
            for ( var i = 0; i < this.elements.length; i++) {
                if (this.elements[i].key == _key) {
                    flag = true;
                    continue;
                }
            }
        } catch (e) {
            flag=false;
        }
        return flag;
    }
    //判断Map中是否存在指定的value值
    this.containsValue=function(_value){
        for ( var i = 0; i < this.elements.length; i++) {
            if(this.elements[i].value==_value){
                return true;
            }
        }
        return false;
    }
    //获取Map中的所有key的数组
    this.keys=function(){
        var arr = new Array();
        for ( var i = 0; i < this.elements.length; i++) {
            arr.push(this.elements[i].key)
        }
        return arr;
    }
    //获取Map中所有的value的数组
    this.values=function(){
        var arr = new Array();
        for ( var i = 0; i < this.elements.length; i++) {
            arr.push(this.elements[i].value)
        }
        return arr;
    }

};

//示例

var map = new Map();

map.get(index);


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JS中的Map对象和普通对象(也称为字面量对象)是两种不同的数据结构。 1. Map对象Map是一种有序的键值对集合,其中键和值可以是任意类型的数据。Map对象提供了一些特定的方法来操作和访问这些键值对。Map对象可以使用构造函数创建,也可以使用字面量语法创建。 示例: ```javascript const map = new Map(); map.set('key1', 'value1'); map.set('key2', 'value2'); console.log(map.get('key1')); // 输出: value1 console.log(map.has('key2')); // 输出: true console.log(map.size); // 输出: 2 ``` 2. 普通对象(字面量对象): 普通对象JS中最常见的数据结构之一,它由一组键值对组成,其中键是字符串类型,值可以是任意类型的数据。可以使用花括号{}和冒号:来创建普通对象。 示例: ```javascript const obj = { key1: 'value1', key2: 'value2' }; console.log(obj.key1); // 输出: value1 console.log('key2' in obj); // 输出: true ``` 区别: - Map对象的键可以是任意类型的数据,而普通对象的键只能是字符串类型。 - Map对象会保持插入顺序,而普通对象不保证键值对的顺序。 - Map对象有一些特定的方法来操作和访问键值对,而普通对象使用点语法或方括号语法来操作和访问键值对。 - Map对象的键值对数量可以通过size属性获取,而普通对象需要手动计算键值对的数量。 总结: 如果需要使用非字符串类型的键,或者需要保持键值对的插入顺序,或者需要使用Map对象提供的特定方法,可以使用Map对象。如果只需要简单地存储和访问键值对,并且键是字符串类型,可以使用普通对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值