Wrong behaviour in Google Chrome Object.defineProperty?

蹲街弑〆低调 提交于 2019-11-29 17:38:49

问题


I am trying to create an object with setters and getters, and this is my code:

var Player = function(height){
    var _height = height;

    Object.defineProperty(this, 'height', {
      enumerable: false
    , configurable: true
    , writable: false
    , get: function(){return _height;}
    , set: function(val){_height = val;}
    });
}

var myPlayer = new Player(10);

Even though the writable property of the defineProperty options is set to false, I get the following error:

Invalid property. A property cannot both have accessors and be writable or have a value, #<Object>

The same is happening when the writable is set to true of course, but the error disappears if I remove the writable line.

Am I doing something wrong, or is this a bug? This is happening on Google Chrome, Version 30.0.1599.66


回答1:


The Mozilla MDN for Object.defineProperty clarifies this:

Property descriptors present in objects come in two main flavors: data descriptors and accessor descriptors. A data descriptor is a property that has a value, which may or may not be writable. An accessor descriptor is a property described by a getter-setter pair of functions. A descriptor must be one of these two flavors; it cannot be both.

This means, that you can use either one of those:

  • writable and value
  • get and set

But you cannot use any combination of them. In your example, you specify the writable attribute, which means that it is a data descriptor, which disallows get and set attributes.



来源:https://stackoverflow.com/questions/19349309/wrong-behaviour-in-google-chrome-object-defineproperty

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!