javascript - 在JS中,什么时候会用到Object.defineProperty()来设置或者修改对象属性?
天蓬老师
天蓬老师 2017-04-11 11:11:46
[JavaScript讨论组]

JS初学:
创建对象时,可以用

var student={
             name:"LILY",
             age:12,
             grade:1
        };

那什么时候用到Object.defineProperty()修改属性值呢?
student.name="pp";
这样修改属性值和defineProperty()有什么区别呢?

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(4)
黄舟
Object.defineProperty(Object.prototype, 'foo', {value: function() {console.log(foo);}});

(这样添加的属性是不可修改不可枚举不可再次配置的)

当你非要给原生类原型添加方法时,不用 defineProperty 就会给其它程序(如 for in)添加麻烦

当然 getter/setter 要兼容性的话也得要,不然

var obj = {
    _name: null,
    get name() {
        return this._name;
    }
    set name(val) {
        this._name = val;
    }
};

会在不支持的浏览器报语法错(没救了,除非 eval)

此时的使用方法:

Object.defineProperty(obj, 'name', {get: function() {return this._name;}, set: function(val) {this._name = val;}});
黄舟

Object.defineProperty可以详细设置属性的可枚举性,可修改性以及getter和setter
所以当你需要一个只读的或者不可被枚举的属性,或者需要在读取或设置值时做一些额外操作,这几种情况下都适合使用Object.defineProperty
参考这里的例子

高洛峰

当你成为大牛的时候你就会需要,譬如:尤小右在他的大作vue里,就用Object.defineProperty做了惊世骇俗的数据绑定,先进程度(黑科技感)远超其他作品,关于详情,看深入响应式原理

巴扎黑

定义一个常量(无法修改)
var CONSTANT = {};
Object.defineProperty(CONSTANT, "PI", {
value: 3.1415,
writable: false,
configurable: false
});

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号