news 2026/2/10 6:18:49

在 Vue 中使用 TypeScript 的几种方式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在 Vue 中使用 TypeScript 的几种方式

Vue中使用TypeScript的几种方式:

  1. 通过<script lang="ts">结合defineComponent;
  2. 推荐使用Composition API + <script setup lang="ts">实现类型推断;
  3. 使用TypeScript定义Props和Emits类型。

配置步骤包括安装依赖、设置tsconfig.json和env.d.ts文件。


使用TypeScript能提供类型安全、更好的IDE支持、清晰的接口定义和更高的代码可维护性。


主流开发工具如VSCode、WebStorm、Vite和Vue CLI都提供良好支持。


在 Vue 中使用 TypeScript 的几种方式

1.使用<script lang="ts">

vue

<template> <div>{{ message }}</div> </template> <script lang="ts"> import { defineComponent } from 'vue' export default defineComponent({ data() { return { message: 'Hello TypeScript!' as string } }, methods: { greet(name: string): string { return `Hello, ${name}!` } } }) </script>

2.使用 Composition API +<script setup lang="ts">(推荐)

vue

<template> <div>{{ message }}</div> <button @click="increment">Count: {{ count }}</button> </template> <script setup lang="ts"> import { ref, computed } from 'vue' // 类型推断 const count = ref(0) // 自动推断为 Ref<number> const message = ref('Hello') // 自动推断为 Ref<string> // 显式类型声明 const user = ref<{ name: string; age: number }>({ name: 'John', age: 25 }) // 类型化的函数 const increment = (amount: number = 1): void => { count.value += amount } // 计算属性自动推断类型 const doubleCount = computed(() => count.value * 2) </script>

3.使用 TypeScript 定义 Props

vue

<template> <div>{{ title }} - {{ count }}</div> </template> <script setup lang="ts"> interface Props { title: string count?: number items: string[] } const props = withDefaults(defineProps<Props>(), { count: 0 }) </script>

4.类型化的 Emits

vue

<script setup lang="ts"> // 定义 emits 的类型 const emit = defineEmits<{ (e: 'update', value: number): void (e: 'submit', data: { name: string; age: number }): void }>() const handleClick = () => { emit('update', 10) emit('submit', { name: 'John', age: 25 }) } </script>

配置步骤

1.安装必要的依赖

bash

npm install -D typescript @vue/tsconfig @vue/runtime-dom # 或 yarn add -D typescript @vue/tsconfig @vue/runtime-dom

2.创建/更新 tsconfig.json

{ "extends": "@vue/tsconfig/tsconfig.dom.json", "include": ["env.d.ts", "src/**/*", "src/**/*.vue"], "exclude": ["src/**/__tests__/*"], "compilerOptions": { "composite": true, "baseUrl": ".", "paths": { "@/*": ["./src/*"] } } }

3.创建 env.d.ts 文件

/// <reference types="vite/client" /> declare module '*.vue' { import type { DefineComponent } from 'vue' const component: DefineComponent<{}, {}, any> export default component }

使用 TypeScript 的好处

  1. 类型安全:在编译时捕获类型错误

  2. 更好的 IDE 支持:自动补全、类型提示、重构

  3. 清晰的接口定义:明确的 Props 和 Emits 类型

  4. 代码可维护性:类型作为文档,提高代码可读性


常见工具支持

  • VSCode:配合 Volar 插件

  • WebStorm:内置支持

  • Vite:开箱即用

  • Vue CLI:通过vue add typescript

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/6 10:39:44

如何用AG-UI构建高效智能应用:完整开发指南

如何用AG-UI构建高效智能应用&#xff1a;完整开发指南 【免费下载链接】ag-ui 项目地址: https://gitcode.com/gh_mirrors/agu/ag-ui 你是否在开发AI应用时遇到这些困扰&#xff1f;实时通信延迟导致用户体验卡顿&#xff0c;多代理协作时的状态同步问题频发&#xff…

作者头像 李华
网站建设 2026/2/6 20:07:58

AI如何解决Office文件解析难题?

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个工具&#xff0c;能够自动检测和修复无效的Office Open XML (OOXML)文件。该工具应支持以下功能&#xff1a;1. 自动扫描文件内容&#xff0c;识别无效的OOXML结构&#x…

作者头像 李华
网站建设 2026/2/8 18:52:07

戴森球计划工厂布局终极指南:从零开始打造高效星际工厂

戴森球计划工厂布局终极指南&#xff1a;从零开始打造高效星际工厂 【免费下载链接】FactoryBluePrints 游戏戴森球计划的**工厂**蓝图仓库 项目地址: https://gitcode.com/GitHub_Trending/fa/FactoryBluePrints 还在为戴森球计划中复杂的工厂设计而烦恼吗&#xff1f;…

作者头像 李华
网站建设 2026/2/6 22:08:41

CLAUDE-CODE-ROUTER:AI如何重构代码路由逻辑

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个基于CLAUDE-CODE-ROUTER的智能代码路由系统。系统需要&#xff1a;1.自动分析现有代码库中的API端点 2.根据调用频率和依赖关系生成路由拓扑图 3.提供动态路由优化建议 4.…

作者头像 李华
网站建设 2026/2/9 13:05:22

Xbox 360改装终极指南:从零开始快速掌握完整流程

Xbox 360改装终极指南&#xff1a;从零开始快速掌握完整流程 【免费下载链接】J-Runner-with-Extras Source code to the J-Runner with Extras executable. Requires the proper support files, package can be found in README 项目地址: https://gitcode.com/gh_mirrors/j…

作者头像 李华
网站建设 2026/2/9 6:31:17

TENGINE在边缘计算设备上的落地实践

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个基于TENGINE的树莓派人脸识别系统。功能要求&#xff1a;1)支持MTCNN人脸检测模型 2)实现人脸特征提取 3)简单的特征比对功能 4)低功耗模式实现。需要包含完整的树莓派环境…

作者头像 李华