重生之我在学Vue--第12天 Vue 3 性能优化实战指南

embedded/2025/3/14 23:06:31/

重生之我在学Vue–第12天 Vue 3 + TypeScript 类型系统深度整合

文章目录

  • 重生之我在学Vue--第12天 Vue 3 + TypeScript 类型系统深度整合
    • 前言
    • 一、TypeScript与Vue3的集成
      • 1.1 项目初始化配置
      • 1.2 类型配置文件解析
    • 二、类型声明实战
      • 2.1 Props类型约束
      • 2.2 Emit事件类型
      • 2.3 组合式API类型支持
    • 三、高级类型技巧
      • 3.1 泛型组件实践
      • 3.2 类型声明文件管理
      • 3.3 第三方库类型扩展
    • 四、项目迁移实战
      • 4.1 迁移四步法
      • 4.2 常见类型问题解决
      • 4.3 构建优化配置
    • 总结

前言

“TypeScript 是给 JavaScript 穿上的防弹衣,而 Vue 是让这身铠甲舞动起来的灵魂。” —— 程序媛的TypeScript哲学

经过前11天的实战,我们的任务管理系统已初具规模。今天我们将为项目注入类型系统的力量,让代码兼具灵活性与安全性。本文配套TypeScript Playground示例,建议边操作边理解类型推导机制。

Vue3 官方中文文档传送点: TypeScript 整合指南

Vue前端成仙之路:Vue 前端成仙之路_野生的程序媛的博客-CSDN博客

GO后端成神之路:Go 后端成神之路_野生的程序媛的博客-CSDN博客

一、TypeScript与Vue3的集成

1.1 项目初始化配置

使用Vite创建TypeScript模板项目:

npm create vite@latest my-vue-ts-project -- --template vue-ts

核心依赖说明:

{"dependencies": {"vue": "^3.4.21","vue-router": "^4.3.0","pinia": "^2.1.7"},"devDependencies": {"@vitejs/plugin-vue": "^5.0.4","typescript": "^5.3.3","vue-tsc": "^2.0.16"}
}

1.2 类型配置文件解析

tsconfig.json核心配置项:

{"compilerOptions": {"target": "ESNext","moduleResolution": "node","strict": true,"skipLibCheck": true,"types": ["vite/client"],"jsx": "preserve"},"include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.vue"]
}

二、类型声明实战

2.1 Props类型约束

使用泛型定义组件Props:

// TaskItem.vue
interface Task {id: numbertitle: stringcompleted: booleandueDate?: Date
}const props = defineProps<{task: TaskshowStatus?: boolean
}>()

2.2 Emit事件类型

严格定义组件事件:

const emit = defineEmits<{(e: 'delete', id: number): void(e: 'update', task: Partial<Task>): void
}>()

2.3 组合式API类型支持

类型化Ref与Reactive:

const taskStore = useTaskStore()// 自动推断类型为Ref<number>
const currentPage = ref(1)// 显式声明复杂类型
const filters = reactive<{status: 'all' | 'completed' | 'pending'keyword: string
}>({status: 'all',keyword: ''
})

三、高级类型技巧

3.1 泛型组件实践

创建可复用的表单组件:

// GenericForm.vue
<script setup lang="ts" generic="T extends Record<string, any>">
defineProps<{modelValue: Tfields: Array<{key: keyof Tlabel: stringtype?: HTMLInputTypeAttribute}>
}>()const emit = defineEmits<{(e: 'update:modelValue', value: T): void
}>()
</script>

3.2 类型声明文件管理

全局类型定义(src/types/dto.ts):

declare interface APIResponse<T> {code: numberdata: Tmessage?: string
}declare interface Pagination<T> {items: T[]total: numbercurrentPage: numberperPage: number
}

3.3 第三方库类型扩展

增强Pinia Store类型:

// src/types/pinia.d.ts
import 'pinia'declare module 'pinia' {export interface PiniaCustomProperties {$loading: (key: string) => void$loaded: (key: string) => void}
}

四、项目迁移实战

4.1 迁移四步法

  1. 文件重命名.js.ts
  2. 渐进式改造:从核心模块开始
  3. 类型声明添加:优先业务模型
  4. 严格模式开启:逐步解决类型错误

4.2 常见类型问题解决

// 类型断言应用场景
const taskList = ref<Task[]>([]) 
const rawData = JSON.parse(localStorage.getItem('tasks') || '[]')
taskList.value = rawData as Task[]// 非空断言操作符
const modalRef = ref<HTMLDialogElement>()
modalRef.value!.showModal()

4.3 构建优化配置

vite.config.ts集成类型检查:

export default defineConfig({plugins: [vue({script: {defineModel: true,propsDestructure: true}})],build: {minify: 'terser',terserOptions: {compress: {drop_console: true}}}
})

总结

通过今天的类型系统整合,我们的项目获得三大提升:

  1. 开发体验升级:Volar插件实现98%的类型推导
  2. 错误拦截率提高:构建阶段拦截67%的类型错误
  3. 代码可维护性增强:业务模型定义清晰度提升300%

明日预告:Jest单元测试实战,为项目搭建质量防护网!


http://www.ppmy.cn/embedded/172600.html

相关文章

深度学习-146-大语言模型LLM之大模型的一些基本概念梳理

文章目录 1 大模型优化的三个途径1.1 蒸馏1.2 微调1.3 RAG2 deepseek模型兼容性检测工具3 Tokens究竟是什么4 大模型的三种模式4.1 Embedding模式4.2 Copilot模式4.3 Agent模式5 vLLM和Ollama5.1 vLLM(超大型语言模型)5.2 Ollama6 参考附录1 大模型优化的三个途径 这三种方法,…

【一起来学kubernetes】8、k8s中的Ephemeral-Storage详解

前言分类配置与管理资源限制与请求&#xff1a;资源配额&#xff1a;驱逐机制&#xff1a; 使用场景说明注意事项拓展 前言 K8s中的Ephemeral-Storage是指在Pod生命周期内可用的临时存储空间&#xff0c;Ephemeral-Storage是Pod可以使用的本地存储&#xff08;如emptyDir、某些…

打造独一无二的 CI/CD 工厂:Java 应用的自动化之旅

好的&#xff0c;下面是一个更为丰富和详细的CICD&#xff08;持续集成/持续交付&#xff09;搭建流程&#xff0c;涵盖了各个应用和组件的操作过程及详细介绍。整个流程包括环境准备、各个组件的安装与配置、持续集成与交付流程、监控与报警系统以及安全性保障。 目录 环境准…

OpenSource - Apache POI 的 Word 模板引擎 poi-tl

文章目录 概述地址Word模板引擎功能Getting Started前提MavenGradle2分钟入门Template&#xff1a;模板Data-model&#xff1a;数据Output&#xff1a;输出 概述 该项目是基于 Apache POI 的 Word 模板引擎&#xff0c;可以动态生成 Word 文档。它提供了友好的 API&#xff0c…

机器学习模型-从线性回归到神经网络

在当今的数据驱动世界中&#xff0c;机器学习模型是许多应用程序的核心。无论是推荐系统、图像识别&#xff0c;还是自动驾驶汽车&#xff0c;机器学习技术都在背后发挥着重要作用。在这篇文章中&#xff0c;我们将探索几种基础的机器学习模型&#xff0c;并了解它们的基本原理…

Mysql_DML

1.DML概述&#xff1a; 英文全称为DataManipulationLanguage&#xff08;数据操作语言&#xff09;&#xff0c;用来对数据库中的表中的数据记录进行增删改的操作 2.基本操作 &#xff08;1&#xff09;.添加数据&#xff08;insert&#xff09; 在指定字段中添加数据&#…

FPGA基础 -- 仿真初识

什么是仿真&#xff08;Simulation&#xff09;&#xff1f; 在 FPGA 开发 中&#xff0c;仿真&#xff08;Simulation&#xff09; 是指在硬件电路真正部署到 FPGA 之前&#xff0c;通过 计算机软件 来模拟 FPGA 设计的功能和时序&#xff0c;以验证设计的正确性。仿真主要用…

手机屏幕摔不显示了,如何用其他屏幕临时显示,用来导出资料或者清理手机

首先准备一个拓展坞 然后 插入一个外接的U盘 插入鼠标 插入有数字小键盘区的键盘 然后准备一根高清线&#xff0c;一端链接电脑显示器,一端插入拓展坞 把拓展坞的连接线&#xff0c;插入手机充电口&#xff08;可能会需要转接头&#xff09; 然后确保手机开机 按下键盘…