es6 getter setter
Posted keatkeat
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了es6 getter setter相关的知识,希望对你有一定的参考价值。
https://stackoverflow.com/questions/34517538/setting-an-es6-class-getter-to-enumerable
1. 我要 getter 没有要暴露
class A { get age() { return 11; } } console.log(Object.keys(new A())); // []
翻译 es5
var A = /** @class */ (function () { function A() { } Object.defineProperty(A.prototype, "age", { get: function () { return 11; }, enumerable: true, configurable: true }); return A; }()); console.log(Object.keys(new A())); // []
由于定义到了 prototype 上,所以 object keys 就找不到了。
2. 我要 getter 要暴露
class A { constructor() { Object.defineProperty(this, ‘age‘, { get: function () { return 11; }, enumerable: true }) } readonly age: number; // 为了智能提示 } console.log(Object.keys(new A())); // []
直接定义到了对象上边而不是 prototype
3. 我要 getter setter 不要暴露全部
by default 是会出现 private _age 的
class A { private _age: number; get age() { return this._age; } set age(value: number) { this._age = value; } } const a = new A(); a.age = 11 console.log(Object.keys(a)); // [‘_age‘]
添加 define
class A { constructor() { Object.defineProperty(this, ‘_age‘, { enumerable: false, writable: true }); } private _age: number; get age() { return this._age; } set age(value: number) { this._age = value; } } const a = new A(); a.age = 15; console.log(Object.keys(a)); console.log(a.age);
4. 我要 getter setter 暴露但不要暴露 private
class A { constructor() { Object.defineProperty(this, ‘_age‘, { enumerable: false, writable: true }); Object.defineProperty(this, ‘age‘, { enumerable: true, get: function () { return this._age; }, set: function (value: number) { this._age = value; } }); } private _age: number; age: number; } const a = new A(); a.age = 15; console.log(Object.keys(a)); console.log(a.age);
以上是关于es6 getter setter的主要内容,如果未能解决你的问题,请参考以下文章
es6 对象的 getter、setter 和函数不适用于远程过程调用 (zerorpc)
JSON 使用 getter/setter 对 ES6 类属性进行字符串化