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())); // ['age']
复制代码

直接定义到了对象上边而不是 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);
复制代码

 

posted @   兴杰  阅读(857)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 百万级群聊的设计实践
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
历史上的今天:
2016-05-18 SQL viewId 比较好看的 Id
点击右上角即可分享
微信分享提示