1

这里

// inherit methods of Date to extend it.
var extendDate=Date.prototype;

// add year property to Date.prototype, thus to an instance of Date
/*extendDate.year={
    get: function() { return this.getFullYear(); },
    set: function(y) { this.setFullYear(y); }
};*/

Object.defineProperty(extendDate, "year", {
  get: function() { return this.getFullYear(); },
  set: function(y) { this.setFullYear(y); }
});


// test year's getter and setter
// first, create an instance of Date
// remember, Date now inherits property year
var now=new Date();
alert(now);
now.year=2000;
alert(now);

使用 Object.defineProperty() 可以按预期工作,但在我使用时却不行

extendDate.year={
        get: function() { return this.getFullYear(); },
        set: function(y) { this.setFullYear(y); }
};

JSFiddle:https ://jsfiddle.net/od53se26/1/

谢谢。

4

2 回答 2

0

使用Object.defineProperty()时,您提供了在访问属性时使用的访问器描述符,而在注释代码中,您只是将对象分配给恰好具有方法的属性。

var obj = Object.prototype;

obj.awesomeProp = {
  get: function() { return 'chicken satay'; }
};
// logs the whole awesomeProp object
console.log(obj.awesomeProp);
// logs "function () { return 'chicken satay'; }"
console.log(obj.awesomeProp.get);

Object.defineProperty(obj, 'anotherProp', {
  get: function() { return 'chicken soup'; }
});
// logs "chicken soup"
console.log(obj.anotherProp);
// logs *undefined*
console.log(obj.anotherProp.get);
于 2016-07-30T04:22:26.407 回答
0

感谢您的澄清。还有一点:因为 Object.prototype 增加了两个额外的属性(awesomeProp 和 anotherProp),所以任何对象实例也继承了这些属性。

jsfiddle https://jsfiddle.net/1nxtmeyu/

var obj = Object.prototype;

obj.awesomeProp = {
  get: function() { return 'chicken satay'; }
};

Object.defineProperty(obj, 'anotherProp', {
  get: function() { return 'chicken soup'; }
});

var AnyObj=function() {};
// AnyObj inherited awesomeProp and anotherProp
var child=new AnyObj();
alert(child.anotherProp);        // alerts chicken soup
alert(child.awesomeProp.get);        // alerts function() { return 'chicken satay'; }

child 从 Object.prototype 继承 awesomeProp 和 anotherProp,如警报所示。

于 2016-07-30T07:18:58.750 回答