Vue3 + TypeScript

Vue3 + TS开发环境创建

1. 创建环境

vite除了支持基础阶段的纯TS环境之外,还支持 Vue + TS开发环境的快速创建, 命令如下:

$ npm create vite@latest  vue-ts-pro -- --template vue-ts 

说明:

  1. npm create vite@latest 基于最新版本的vite进行项目创建
  2. vue-ts-pro 项目名称
  3. – --template vue-ts 选择Vue + TS的开发模板

2. 和.vue文件相关的工具

开发阶段

  1. Vue Language Features (Volar)工具对.vue文件进行实时的类型错误反馈
  2. TypeScript Vue Plugin (Volar) 工具用于支持在 TS 中 import *.vue 文件

打包阶段
vue-tsc工具负责打包时最终的类型检查
在这里插入图片描述

好处:开发阶段的类型提示交给IDE做,保证vite的运行速度,打包阶段做’兜底类型校验’,确保类型无误

为Ref标注类型

1. 场景和好处

为ref标注类型之后,既可以在给ref对象的value赋值时校验数据类型,同时在使用value的时候可以获得代码提示
在这里插入图片描述

说明:本质上是给ref对象的value属性添加类型约束

2. 如何标注

ref 函数和 TS 的配合通常分为俩种情况,类型推导和泛型指定类型

  1. 如果是简单的数据,推荐使用类型推导
    在这里插入图片描述

  2. 如果是较复杂的数据,通过泛型指定类型
    在这里插入图片描述

3. 思考题

标注ref函数类型,可以满足把下图所示的数据赋值给value属性
在这里插入图片描述

<script setup lang="ts">
import { ref } from 'vue'type Item = {id: stringname: stringage: number
}
const list = ref<Item[]>([])
list.value = [{ id: '1', name: 'lxx', age: 19 },{ id: '2', name: 'lss', age: 15 }
]
</script><template><div v-for="item in list" :key="item.id">{{ item.name + ' : ' + item.age }}</div>
</template><style scoped></style>

为computed标注类型

1.如何进行类型标注

计算属性通常由已知的响应式数据计算得到,所以依赖的数据类型一旦确定通过自动推导就可以知道计算属性的类型另外根据最佳实践,计算属性多数情况下是只读的,不做修改,所以配合TS一般只做代码提示

const count = ref(0)
const doubleCount = computed(() => count.value * 2)

鼠标放在doubleCount可以得到推导结果

const doubleCount:ComputedRef<number>

2.更复杂的例子

需求:给ref函数标注类型,接收后端返回的对象列表,然后使用计算属性做过滤计算,计算得到单价大于500的商品

<script setup lang="ts">
import { computed, ref } from 'vue'
const data = [{ id: '1001', name: '男鞋', price: 888 },{ id: '1002', name: '女鞋', price: 232 },{ id: '1003', name: '童鞋', price: 333 }
]type Item = {id: stringname: stringprice: number
}const list = ref<Item[]>(data)
const filterList = computed(() => list.value.filter(item => item.price > 500))
</script><template>{{ list }}<hr />{{ filterList }}
</template><style scoped></style>
list的类型为:
const list: Ref<{id: string;name: string;price: number;
}[]>filterList推导出的类型为:
const filterList: ComputedRef<{id: string;name: string;price: number;
}[]>

为事件处理函数标注类型

1. 为什么需要标注类型

原生dom事件处理函数的参数默认会自动标注为any类型,没有任何类型提示,为了获得良好的类型提示,需要手动标注类型
在这里插入图片描述

2. 如何标注类型

  1. 给事件对象形参 e 标注为Event类型,可以获得事件对象的相关类型提示
    在这里插入图片描述

  2. 如果需要更加精确的DOM类型提示可以使用断言(as)进行操作
    在这里插入图片描述

3.思考题

如何给按钮元素button的点击事件函数标注类型?

<script setup lang="ts">
const clickHandler = (e: Event) => {console.log(e.target as HTMLButtonElement)
}
</script><template><button @click="clickHandler">click</button>
</template><style scoped></style>

为模版引用标注类型

1. 为什么需要类型标注

给模版引用标注类型,本质上是给ref对象的value属性添加了类型约束,约定value属性中存放的是特定类型的DOM对象,从而在使用的时候获得相应的代码提示

在这里插入图片描述

2. 如何进行类型标注

通过具体的DOM类型联合null做为泛型参数, 比如我们想获取一个input dom元素
在这里插入图片描述

3. 思考题

尝试为模版引用标注类型获取一个a元素?

<script setup lang="ts">
import { onMounted, ref } from 'vue'
const aRef = ref<HTMLAnchorElement | null>(null)
onMounted(() => {//aRef.value存放的数据在组件渲染完毕之前是null//渲染完毕之后才是真实的dom// 可选链.?console.log(aRef.value?.href)
})
</script><template><a href="#" ref="aRef">xxx</a>
</template><style scoped></style>

对象的非空值处理

1. 空值场景说明

当对象的属性可能是 null 或 undefined 的时候,称之为“空值”,尝试访问空值身上的属性或者方法会发生类型错误
在这里插入图片描述

说明:inputRef变量在组件挂载完毕之前,value属性中存放的值为null,不是input dom对象,通不过类型校验

2. 可选链方案

可选链 ?. 是一种访问嵌套对象属性的安全的方式, 可选链前面的值为 undefined 或者 null时,它会停止运算
在这里插入图片描述

3. 逻辑判断方案

通过逻辑判断,只有有值的时候才继续执行后面的属性访问语句
在这里插入图片描述

4. 非空断言方案

非空断言(!)是指我们开发者明确知道当前的值一定不是null或者undefined,让TS通过类型校验
在这里插入图片描述

特别注意: 使用非空断言要格外小心,它没有实际的JS判断逻辑,只是通过了TS的类型校验,容易直接把空值出现在实际的执行环境里

为组件的Props标注类型

1. 为什么给Props标注类型

给组件的Props标注类型有俩个作用,一个是确保传递的prop是类型安全的,另一个在组件内部使用的时候也会有类型提示
在这里插入图片描述

在这里插入图片描述

2. 基础使用

语法:通过defineProps宏函数对组件props进行类型标注
需求:按钮组件有俩个prop参数,color类型为string且为必填,size类型为string且为可选,怎么定义类型?
在这里插入图片描述

说明:按钮组件传递prop属性的时候必须满足color是必传项且类型为string, size为可选属性,类型为string

3. Props默认值设置

场景:Props中的可选参数通常除了指定类型之外还需要提供默认值,可以使用withDefaults宏函数来进行设置
需求:按钮组件的size属性的默认值设置为 middle
在这里插入图片描述

说明:如果用户传递了size属性,按照传递的数据来,如果没有传递,则size值为 ’middle’

4. 思考题

给按钮组件添加一个btnType属性,类型为 ’success‘, ‘danger’ 或者 ’warning‘ 三选一, 默认值为 ’success‘

<script setup lang="ts">
import MyButton from './components/MyButton.vue'
</script><template><MyButton btn-type="success"></MyButton><MyButton></MyButton>
</template><style scoped></style>

MyButton子组件

<script setup lang="ts">
type Props = {btnType?: 'success' | 'danger' | 'warning'
}const props = withDefaults(defineProps<Props>(), {btnType: 'success'
})console.log(props.btnType)
</script><template></template><style scoped></style>

为组件的emits标注类型

1. 为什么需要标注类型

在这里插入图片描述

作用:可以约束事件名称并给出自动提示,确保不会拼写错误,同时约束传参类型,不会发生参数类型错误

2. 何为组件的emits标注类型

语法:通过 defineEmits 宏函数进行类型标注
需求:子组件触发一个名称为 ’get-msg‘ 的事件,并且传递一个类型为string的参数
在这里插入图片描述

<script setup lang="ts">
import MyButton from './components/MyButton.vue'const getMesageHandler = (e: string) => console.log(e)
</script><template><MyButton @get-msg="getMesageHandler"></MyButton>
</template><style scoped></style>
<script setup lang="ts">
//定义事件类型Emits
type Emits = { // 事件名称		事件参数类型(e: 'get-msg', msg: string): void 
}
//给emits标注类型
const emits = defineEmits<Emits>()
</script><template><!-- 触发自定义事件 --><button @click="emits('get-msg', 'xxx')">按钮</button>
</template><style scoped></style>

3. 思考题

Son组件再触发一个事件’get-list’, 传递参数类型为下图所示的数据类型
在这里插入图片描述

<script setup lang="ts">
import Son from './components/Son.vue'type Item = {id: numbername: string
}
const getListHandler = (e: Item[]) => e.forEach(item => console.log(item.id + ':' + item.name))
</script><template><Son @get-list="getListHandler"></Son>
</template><style scoped></style>
<script setup lang="ts">
type Item = {id: numbername: string
}
type Emits = { (e: 'get-list', msg: Item[]): void }
const emits = defineEmits<Emits>()const clickHandler = () => {const list = [{ id: 1001, name: 'lxx' },{ id: 1002, name: 'kobe' }]emits('get-list', list)
}
</script><template><button @click="clickHandler">按钮</button>
</template><style scoped></style>

类型声明文件

1. 什么是类型声明文件

概念:在TS中以d.ts为后缀的文件就是类型声明文件,主要作用是为js模块提供类型信息支持,从而获得类型提示
在这里插入图片描述

说明:

  1. d.ts是如何生效的?
    在使用js某些模块的时候,TS会自动导入模块对应的d.ts文件,以提供类型提示
  2. d.ts是怎么来的?
    库如果本身是使用TS编写的,在打包的时候经过配置自动生成对应的d.ts文件(axios本身就是TS编写的)

2. 使用 DefinitelyTyped 提供类型声明文件

场景:有些库本身并不是采用TS编写的,无法直接生成配套的d.ts文件,但是也想获得类型提示,此时需要 Definitely Typed 提供类型声明文件
在这里插入图片描述

DefinitelyTyped是一个TS类型定义的仓库,专门为JS编写的库可以提供类型声明,比如可以安装 @types/jquery 为jquery提供类型提示
在这里插入图片描述

3. TS内置类型声明文件

TS为JS运行时可用的所有标准化内置API都提供了声明文件,这些文件既不需要编译生成,也不需要三方提供

在这里插入图片描述

说明:这里的lib.es5.d.ts以及lib.dom.d.ts都是内置的类型声明文件,为原生js和浏览器API提供类型提示

4. 自定义类型声明文件

d.ts文件在项目中是可以进行自定义创建的,通常有俩种作用,第一个是共享TS类型(重要),第二种是给js文件提供类型(了解)

场景一:共享TS类型

在这里插入图片描述

说明:哪个业务组件需要用到类型导入即可,为了区分普通模块,可以加上type关键词

场景二:给JS文件提供类型
在这里插入图片描述

说明:通过declare关键词可以为js文件中的变量声明对应类型,这样js导出的模块在使用的时候也会获得类型提示

5. .ts文件和d.ts文件对比

TS中有俩种文件类型,一种是.ts文件,一种是.d.ts文件
.ts文件

  1. 既可以包含类型信息也可以写逻辑代码
  2. 可以被编译为js文件

.d.ts文件

  1. 只能包含类型信息不可以写逻辑代码
  2. 不会被编译为js文件,仅做类型校验检查

综合案例

完整代码

https://gitee.com/lxxkobe/vue3-ts.git

在这里插入图片描述

频道列表渲染 - 类型思想转变

之前业务开发我们用的是JavaScript,现在要加上TypeScript的类型,该如何把类型加进来呢?
在这里插入图片描述
核心思想:使用TS之后的业务开发思想是保持一致的,重要的是根据接口格式定义响应式数据的类型以及axios返回数据的类型即可

频道列表渲染 - 定义axios的返回数据类型

在这里插入图片描述
image.png
说明: 我们通过泛型参数传给request方法的ChannelRes类型约束了axios返回值res的data属性的类型

文章列表渲染

基础文章列表实现(固定频道id)

  1. 根据接口格式定义数据类型
  2. 使用 ref 函数定义响应式数据
  3. 使用 axios 请求数据并赋值给响应式数据
  4. 数据绑定到模版显示

频道和文章列表联动实现(切换不同的频道id)

  1. 为List组件定义 props 类型
  2. 传递当前频道的 id,使用当前id获取列表

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/169752.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Maven】VSCode Java+Maven 环境配置

0x00 前言 没写过 Java&#xff0c;得配个带 Maven 的编码环境&#xff0c;不太明白&#xff0c;试试看顺便记录一下 0x01 配置过程 安装 jdk1.8 后&#xff0c;找到安装位置&#xff1a; (base) dianCD-Ali doraemon % /usr/libexec/java_home -V Matching Java Virtual Ma…

SpringBoot项目中使用MybatisPlus

MybatisPlus的优点 使用时注意事项: 首先需要在spring boot启动类中添加MapperScan注解&#xff0c;扫描Mapper文件夹。 并且在POM文件引入坐标的时候不要同时引入Mybatis和Mybatis-Plus的坐标。容易出现版本差异不兼容。 日志配置 由于SQL的执行是不可见的&#xff0c;所以…

React-Redux总结含购物车案例

React-Redux总结含购物车案例 reduc简介 redux是react全家桶的一员&#xff0c;它为react给i共可预测化的状态管理机制。redux是将整个应用状态存储到一个地方&#xff0c;成为store,里面存放着一颗树状态(state,tree),组件可以派发dispatch行为action给store,而不是直接通知其…

Java实现ORM第一个api-FindAll

经过几天的业余开发&#xff0c;今天终于到ORM对业务api本身的实现了&#xff0c;首先实现第一个查询的api 老的C#定义如下 因为Java的泛型不纯&#xff0c;所以无法用只带泛型的方式实现api&#xff0c;对查询类的api做了调整&#xff0c;第一个参数要求传入实体对象 首先…

python中可变类型与不可变类型详细介绍

嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 一.可变类型与不可变类型的特点 1.不可变数据类型 不可变数据类型在第一次声明赋值声明的时候, 会在内存中开辟一块空间, 用来存放这个变量被赋的值, 而这个变量实际上存储的, 并不是被赋予的这个值, 而是存放这个值所在空…

回归预测 | MATLAB实现BO-GRU贝叶斯优化门控循环单元多输入单输出回归预测

回归预测 | MATLAB实现BO-GRU贝叶斯优化门控循环单元多输入单输出回归预测 目录 回归预测 | MATLAB实现BO-GRU贝叶斯优化门控循环单元多输入单输出回归预测效果一览基本介绍模型搭建程序设计参考资料 效果一览 基本介绍 MATLAB实现BO-GRU贝叶斯优化门控循环单元回归预测。基于贝…

字节码进阶之JVM Attach API详解

字节码进阶之JVM Attach API详解 文章目录 字节码进阶之JVM Attach API详解附加到虚拟机加载代理和获取信息分离虚拟机 使用Attach API的基本步骤1. **获取虚拟机实例**&#xff1a;2. **附加到虚拟机**&#xff1a;3. **加载代理或获取信息**4. **从虚拟机分离**&#xff1a;…

C语言-面试题实现有序序列合并

要求&#xff1a; a.输入两个升序排列的序列&#xff0c;将两个序列合并为一个有序序列并输出。 数据范围&#xff1a; 1≤n,m≤1000 1≤n,m≤1000 &#xff0c; 序列中的值满足 0≤val≤30000 输入描述&#xff1a; 1.输入包含三行&#xff0c; 2.第一行包含两个正整数n, m&am…

python网络爬虫(二)基本库的使用urllib/requests

使用urllib 了解一下 urllib 库&#xff0c;它是 Python 内置的 HTTP 请求库&#xff0c;也就是说不需要额外安装即可使用。它包含如下 4 个模块。 request&#xff1a;它是最基本的 HTTP 请求模块&#xff0c;可以用来模拟发送请求。就像在浏览器里输入网址然后回车一样&…

html web前端,登录,post请求提交 json带参

html web前端&#xff0c;登录&#xff0c;post请求提交 json带参 3ca9855b3fd279fa17d46f01dc652030.jpg <!DOCTYPE html> <html><head><meta http-equiv"Content-Type" content"text/html; charsetutf-8" /><title></t…

rust学习——方法 Method

文章目录 方法 Method定义方法self、&self 和 &mut self方法名跟结构体字段名相同 带有多个参数的方法关联函数多个 impl 定义为枚举实现方法 rust 结构体与枚举的区别回答1回答2 方法 Method 从面向对象语言过来的同学对于方法肯定不陌生&#xff0c;class 里面就充斥…

Python-----for循环基本语法及其应用---对序列进行遍历循环

for循环基本语法 for循环结构主要用于&#xff08;序列 &#xff1a;包括 字符串、列表、元组、集合以及字典&#xff09;类型数据的遍历&#xff08;循环&#xff09;操作。 遍历(Traversal)&#xff0c;是指沿着某条搜索路线&#xff0c;依次对树&#xff08;或图&#…

nodejs+wasm+rust debug及性能分析

文章目录 背景v8引擎自带的profilelinux的perf采集wasm三方库性能分析编译debug版本wasmrust程序debug调试异常模型正常模型结论优化 参考 Node使用火焰图优化CPU爆涨 - 掘金 【Node.js丨主题周】理解perf 与火焰图-腾讯云开发者社区-腾讯云 Easy profiling for Node.js Applic…

RK3568平台开发系列讲解(应用篇)串口应用编程之串口的使用步骤

🚀返回专栏总目录 文章目录 一、配置参数1.1、获取当前串口的配置参数1.2、修改和写入串口的配置参数二、模式2.1、输入模式2.2、输出模式2.3、控制模式2.4、本地模式2.5、特殊控制字符沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 串口设备是嵌入式开发中最常用的…

Node.js在Python中的应用实例解析

随着互联网的发展&#xff0c;数据爬取成为了获取信息的重要手段。本文将以豆瓣网为案例&#xff0c;通过技术问答的方式&#xff0c;介绍如何使用Node.js在Python中实现数据爬取&#xff0c;并提供详细的实现代码过程。 Node.js是一个基于Chrome V8引擎的JavaScript运行时环境…

Flutter的Invalid use of a private type in a public API警告

文章目录 问题描述有问题的源码 问题原因解决方法 问题描述 自己在写Flutter 应用时发现了一个Invalid use of a private type in a public API警告。 发现很多官方的例子也有这个问题。 有问题的源码 有问题的源码如下&#xff1a; class MyTabPage extends StatefulWid…

【三维重建-PatchMatchNet复现笔记】

【三维重建-PatchMatchNet复现笔记】 1 突出贡献2 数据集描述3 训练PatchMatchNet3.1 输入参数3.2 制定数据集加载方式 1 突出贡献 在计算机GPU和运行时间受限的情况下&#xff0c;PatchMatchNet测试DTU数据集能以较低GPU内存和较低运行时间&#xff0c;整体误差位列中等&#…

python sqlalchemy(ORM)- 02 表关系

文章目录 表关系ORM表示 1v1ORM表示 1vm 表关系 1:1&#xff0c;表A 中的一条记录&#xff0c;仅对应表B中的一条记录&#xff1b;表B的一条记录&#xff0c;仅对应表A的一条记录。1:m&#xff0c;表A中的一条记录&#xff0c;对应表B中的多条记录&#xff0c;表B中的一条记录…

【机器学习】集成学习Boosting

文章目录 集成学习BoostingAdaBoost梯度提升树GBDTXGBoostxgboost库sklearn APIxgboost库xgboost应用 集成学习 集成学习&#xff08;ensemble learning&#xff09;的算法主要包括三大类&#xff1a;装袋法&#xff08;Bagging&#xff09;&#xff0c;提升法&#xff08;Boo…

在 Python 中使用 Pillow 进行图像处理【2/4】

第二部分 一、说明 该文是《在 Python 中使用 Pillow 进行图像处理》的第二部分&#xff0c;主要介绍pil库进行一般性处理&#xff1a;如&#xff1a;图像卷积、钝化、锐化、阈值分割。 二、在 Python 中使用 Pillow 进行图像处理 您已经学习了如何裁剪和旋转图像、调整图像大…