码迷,mamicode.com
首页 > Web开发 > 详细

js中的Object

时间:2019-02-02 23:26:17      阅读:236      评论:0      收藏:0      [点我收藏+]

标签:ring   pre   als   table   rop   读取   不能   枚举   class   

js中的Object

  1. 浅克隆

    var obj = {
        a: 1,
        b: 2,
        c: 3
    }
    
    方式一:
        var o = Object.assign({}, obj);
    方式二:
        var {...o} = obj;
  2. 深克隆

    JSON.parse(JSON.stringify(obj))
  3. freeze

    浅冻结,属性值不能修改,但是嵌套的引用类型不起作用
        Object.freeze(obj);
        obj.a = 11 // 修改属性无效
  4. seal

    密封对象,不能添加和删除属性
        Object.seal(obj);
        obj.d = 33; // 添加新属性无效
  5. 只读属性

    var obj = {
        a: 1,
        b: 2
    }
    Object.defineProperty(obj, "c", {value: 3, writable: false});
    obj.c = 4; // 无效
    console.log(obj.c);
  6. 不可枚举属性

    var obj = {
        a: 1,
        b: 2
    }
    Object.defineProperty(obj, "c", {value: 3, enumerable: false});
    
    for(let item in obj) {
        console.log(obj[item]); // 1 2
    }
  7. 不可重新配置属性

    var obj = {
        a: 1,
        b: 2
    }
    Object.defineProperty(obj, "c", {value: 3, enumerable: false, configurable: false});
    Object.defineProperty(obj, "c", {value: 3, enumerable: true}); // 报错
  8. 读取属性的配置信息

    var obj = {
        a: 1,
        b: 2
    }
    Object.defineProperty(obj, "c", {value: 3, enumerable: false, configurable: false});
    console.log(Object.getOwnPropertyDescriptor(obj, "c")); 
    输出信息
        { 
            value: 3,
            writable: false,
            enumerable: false,
            configurable: false 
        }
  9. get和set

    var obj = {
        a: 1,
        b: 2
    }
    Object.defineProperty(obj, "bb", {
        get: function() {
            console.log("取值");
            return this.b;
        },
        set: function(value) {
            console.log("赋值", value);
            this.b=value;
        }
    });
    
    obj.bb=1;  // 赋值 1
    console.log(obj.bb);

js中的Object

标签:ring   pre   als   table   rop   读取   不能   枚举   class   

原文地址:https://www.cnblogs.com/ye-hcj/p/10349215.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!