在 TS 的 class 中,如何防止外部实例化

在 TypeScript(TS)中,如果你想要防止一个类被外部实例化,你可以采取以下几种策略:

  1. 将构造函数设为私有(Private Constructor)

    通过将类的构造函数设为私有,你可以阻止外部代码创建该类的实例。这种技术通常用于实现单例模式、工厂模式或静态类(即只包含静态方法和属性的类)。

    typescript 复制代码
    class PrivateConstructorClass {
        private static instance: PrivateConstructorClass;
    
        private constructor() {
            // 私有构造函数,防止外部实例化
        }
    
        // 静态方法用于获取类的唯一实例(单例模式示例)
        public static getInstance(): PrivateConstructorClass {
            if (!PrivateConstructorClass.instance) {
                PrivateConstructorClass.instance = new PrivateConstructorClass();
            }
            return PrivateConstructorClass.instance;
        }
    
        // 其他类方法和属性...
    }
    
    // 尝试外部实例化会报错
    // const instance = new PrivateConstructorClass(); // 错误:构造函数 'PrivateConstructorClass.constructor' 是私有的。
    
    const instance = PrivateConstructorClass.getInstance(); // 正确:使用静态方法获取实例
  2. 使用抽象类(Abstract Class)

    如果你想要定义一个类,但不允许它直接实例化,你可以将其定义为一个抽象类。抽象类不能被实例化,但可以作为其他类的基类。

    typescript 复制代码
    abstract class AbstractClass {
        // 抽象方法和属性(可选)
        abstract someMethod(): void;
    
        // 具体方法和属性
        concreteMethod() {
            console.log("This is a concrete method.");
        }
    }
    
    // 尝试实例化抽象类会报错
    // const instance = new AbstractClass(); // 错误:不能实例化抽象类 'AbstractClass'。
    
    class ConcreteClass extends AbstractClass {
        someMethod() {
            console.log("Implementing someMethod from AbstractClass.");
        }
    }
    
    const concreteInstance = new ConcreteClass(); // 正确:实例化具体类
  3. 使用静态工厂方法(Static Factory Method)

    虽然这不是直接防止外部实例化的方法,但你可以通过提供一个静态工厂方法来控制实例的创建。这样,即使构造函数是公开的,外部代码也只能通过你提供的工厂方法来获取实例。

    typescript 复制代码
    class FactoryClass {
        private static instances: FactoryClass[] = [];
    
        private constructor() {
            // 仍然可以私有,但这里为了展示工厂方法,我们保持其公开
        }
    
        public static createInstance(): FactoryClass {
            const instance = new FactoryClass();
            FactoryClass.instances.push(instance);
            return instance;
        }
    
        // 其他类方法和属性...
    }
    
    const instance1 = FactoryClass.createInstance();
    const instance2 = FactoryClass.createInstance();
    
    // 注意:虽然构造函数是公开的,但外部代码仍然只能通过 createInstance 方法来获取实例。

    在这个例子中,虽然 FactoryClass 的构造函数是公开的,但外部代码被引导使用 createInstance 静态方法来获取实例。这种方式并不完全防止外部实例化(因为构造函数仍然是公开的),但它提供了一种控制实例创建的方式。

通常,将构造函数设为私有是实现这一目的最直接和有效的方法。如果你不需要单例模式或工厂模式,只需简单地将构造函数设为私有即可。

相关推荐
MIka1 天前
CopilotKit 入门:用 Runtime 和 React Core 搭建真正可用的 AI Copilot
人工智能·typescript·agent
学以智用1 天前
# TypeScript 高级特性(核心+实用)
前端·javascript·typescript
学以智用1 天前
TypeScript 核心基础:类型/变量 + 函数 + 接口
前端·javascript·typescript
蕨类植物1 天前
Fastify 模块化项目实战(二) — 初始化Fastify 项目
typescript
蕨类植物1 天前
Fastify 模块化项目实战 - 你真的懂 tsconfig.json 吗?
typescript
We་ct1 天前
LeetCode 74. 搜索二维矩阵:两种高效解题思路
前端·算法·leetcode·矩阵·typescript·二分查找
回到原点的码农1 天前
TypeScript 与后端开发Node.js
javascript·typescript·node.js
Irene19911 天前
TypeScript 中,Pick 和 Omit 是两个非常常用且强大的内置工具类型(Utility Types)
typescript·pick·omit
江澎涌1 天前
鸿蒙动态导入实战
android·typescript·harmonyos
SuperEugene2 天前
TypeScript+Vue 实战:告别 any 滥用,统一接口 / Props / 表单类型,实现类型安全|编码语法规范篇
开发语言·前端·javascript·vue.js·安全·typescript