typescript-类的静态属性和静态方法

我们上一节看到了类,里面都是类的实例属性和实例方法,即需要实例化后才可以进行访问的。

什么是静态属性和静态方法?

静态属性和静态方法是不需要实例化就可以访问的属性和方法(不需要实例化是指不需要new来生成对象)。

还是以上一节的Person类举例,比如,人都有头发,且都是黑色头发(大家别强,就是黑色的,哈哈)

复制代码
class Person {
    public static blackHair: string = "黑色头发";
    public static washHair(): void {
        console.log("洗头发 ", Person.blackHair);
    }
    public grabHair(): void {
        console.log("抓头发 " + Person.blackHair);
    }
}

console.log(Person.blackHair);
Person.washHair();
let person = new Person();
person.grabHair();
TypeScript 复制代码
tsc index.ts

在浏览器控制台查看

可以看到,静态属性和方法不需要实例化就可以访问

静态属性和方法的用法-单例模式

这里举一个常用的小用法,会涉及到一些其他的知识,就是后面讲的访问权限以及设计模式

假设这样一个场景,在你的应用中,一个Person只能有一个实例对象,不可以实例多个,说白了你的应用中只能有一个人,这个世界上只能有一个人,不能有第二个,这个就要用到我们的单例模式了。看以下代码

TypeScript 复制代码
class Person {
    private static instance = null;
    public hair: string = "黑色头发";
    public static getInstance(): Person {
        if (!Person.instance) {
            Person.instance = new Person();
        }
        return Person.instance;
    }
    private constructor() {}
}

console.log(Person.getInstance().hair);
TypeScript 复制代码
tsc index.ts

查看控制台输出

以上的Person有一个公用的静态方法getInstance,以及一个私有的静态属性instance,这里的构造函数也是私有的,即不能直接在外面通过new来生成实例。这就保证了想要获取这个person的实例,只能用Person.getInstance()来获取。

相关推荐
吴声子夜歌11 分钟前
ES6——Iterator和for...of循环详解
前端·javascript·es6
小李子呢021115 分钟前
前端八股3---ref和reactive
开发语言·前端·javascript
落魄江湖行19 分钟前
基础篇三 Nuxt4 组件进阶:插槽与事件传递
前端·nuxt4
kerli20 分钟前
Compose 组件:LazyColumn 核心参数与 key/contentType 详解
android·前端
好运的阿财21 分钟前
“锟斤拷”问题——程序中用powershell执行命令出现中文乱码的解决办法
linux·前端·人工智能·机器学习·架构·编辑器·vim
踩着两条虫32 分钟前
VTJ.PRO AI + 低代码实战:接入高德地图
前端·vue.js·ai编程
绝世唐门三哥33 分钟前
React性能优化:memo、useMemo和useCallback全解析
前端·react.js·memo
兔子零102435 分钟前
Claude Code 都把宠物养进终端了,我做了一个真正能长期玩的中文宠物游戏
前端·游戏·游戏开发
xiaotao13136 分钟前
Vite 与 Webpack 开发/打包时环境变量对比
前端·vue.js·webpack
摆烂工程师40 分钟前
教你如何查询 Codex 最新额度是多少,以及 ChatGPT Pro、Plus、Business 最新额度变化
前端·后端·ai编程