首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >TypeScript -如何防止用构造函数中的变量覆盖类方法

TypeScript -如何防止用构造函数中的变量覆盖类方法
EN

Stack Overflow用户
提问于 2019-06-24 17:34:09
回答 1查看 666关注 0票数 1

我有一个很大的代码库,其中一些类成员被设置了两次--一次作为方法,另一次显式地在构造函数中设置。

下面是一个例子,说明这可能是什么样子:

代码语言:javascript
运行
复制
class SuperHero {
    public name: string;

    constructor(name: string) {
        this.name = name;

        // This line is a problem.
        this.hasCape = () => {
            return this.name === 'Batman';
        };
    }

    // I want this to be the canonical implementation.
    public hasCape() {
        return this.name === 'Batman' || this.name === 'Wonder Woman';
    }
}

看起来public readonly hasCape()是无效的语法。

是否有一种方法在编译器或linter级别将方法声明强制为规范?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-06-24 21:27:44

受到Aaron Beall评论的启发。这使得hasCape成为一个属性,这是一个函数,这是只读的。然后,类型记录编译器在从构造函数分配它时抛出一个错误。

代码语言:javascript
运行
复制
    public get hasCape() {
        return () => this.name === 'Batman' || this.name === 'Wonder Woman';
    }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56741433

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档