【前端vue3】TypeScrip-interface(接口)和对象类型

对象类型

定义对象需要用到interface(接口),主要用来约束数据的类型满足格式

定义方式如下:

javascript 复制代码
interface Person {
    name: string;
    age: number;
}

如对象中与接口中的属性不一致会报错,必须保持一致

例如如下:

javascript 复制代码
interface Person {
    name: string;
    age: number;
}

const person: Person = {
    name:"小C学安全"
}
//会提示类型 "{ name: string; }" 中缺少属性 "age",但类型 "Person" 中需要该属性。ts(2741)

接口的重合和继承

重合interface,可以合并两个相同对象名的属性

例如:

javascript 复制代码
interface Person {
    name: string;
}
interface Person {
    age: number;
}
const person: Person = {
    name:"小C学安全",
    age: 20
}

继承interface,例如对象A可以继承对象B的属性

例如:

javascript 复制代码
interface PersonA {
    name: string;
}
interface PersonB extends PersonA {
    age: number;
}
const person: PersonB = {
    name:"小C学安全",
    age: 20
}

可选属性

可选属性就是该属性是可以不存在的

例如:

javascript 复制代码
interface PersonA {
    name: string;
    age?: number;
}

const person: PersonA = {
    name:"小C学安全",
}
//这样写是不会报错的

也可以这么写
interface PersonA {
    name: string;
    age?: number;

}

const person: PersonA = {
    name:"小C学安全",
    age: 20
}

任意属性

定义方式: [propName: string]

javascript 复制代码
interface PersonA {
    name: string;
    age?: number; //定义可选属性
    [propName: string]:any; //定义任意属性

}

const person: PersonA = {
    name:"小C学安全",
    age: 20,
    city: "北京"
}

以上代码中,PersonA并没有定义属性city,但是代码没有报错,是因为我们定义了任意属性

只读属性

只读属性是只能读取,但是不允许被赋值修改的

定义方式:在属性前加上readonly

例如:

javascript 复制代码
interface PersonA {
    readonly name: string;
    age?: number; //定义可选属性
    [propName: string]:any; //定义任意属性


}

const person: PersonA = {
    name:"小C学安全",
    age: 20,
    city: "北京"
}

person.name= "小白"

以上代码就会报错,会提示:

无法为"name"赋值,因为它是只读属性。ts(2540)

添加函数

可以给对象属性添加函数

例如:

javascript 复制代码
interface PersonA {
    readonly name: string;
    age?: number; //定义可选属性
    [propName: string]:any; //定义任意属性
    test : ()=>void; // 定义函数
}

const person: PersonA = {
    name:"小C学安全",
    age: 20,
    city: "北京",
    test: ()=>{
        console.log("定义函数成功")
    }
}

person.test()
相关推荐
哆啦A梦15883 分钟前
Vue3魔法手册 作者 张天禹 02
前端·vue.js·typescript
老前端的功夫7 分钟前
抛弃 `!important`,让 CSS 优先级变大
前端·javascript·css·npm·node.js
熊文豪12 分钟前
Tomcat+cpolar 让 Java Web 应用随时随地可访问
java·前端·tomcat·cpolar
衫水13 分钟前
如何在离线情况下部署项目(前端VUE + 后端Python)
前端·vue.js·python
南棱笑笑生13 分钟前
20260123让天启AIO-3576Q38开发板在天启Buildroot下适配摄像头模块8ms1m【预览】
java·前端·数据库·rockchip
Sylvia33.15 分钟前
如何获取足球数据统计数据API
java·前端·python·websocket·数据挖掘
沛沛老爹17 分钟前
从Web到AI:Agent Skills安全架构实战——权限控制与数据保护的Java+Vue全栈方案
java·开发语言·前端·人工智能·llm·安全架构·rag
小飞大王66621 分钟前
使用nodejs接入ai服务并使用sse技术处理流式输出实现打字机效果
前端·javascript·人工智能
极客小云25 分钟前
【React + TypeScript 实现高性能多列多选组件】
前端·react.js·typescript
bin915329 分钟前
(文后附完整代码)html+css+javascript 弹球射击游戏项目分析
前端·javascript·css·游戏·html·前端开发