当前位置: 首页 > wzjs >正文

网站搭建哪里找有名气门户网站首页设计

网站搭建哪里找有名气,门户网站首页设计,免费咨询皮肤科医生在线,临沂网站建设wyjzgzs重生之我在学Vue–第12天 Vue 3 TypeScript 类型系统深度整合 文章目录 重生之我在学Vue--第12天 Vue 3 TypeScript 类型系统深度整合前言一、TypeScript与Vue3的集成1.1 项目初始化配置1.2 类型配置文件解析 二、类型声明实战2.1 Props类型约束2.2 Emit事件类型2.3 组合式AP…

重生之我在学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://eMFm6I3E.jppzj.cn
http://OyAiBFAS.jppzj.cn
http://gd3SaS0y.jppzj.cn
http://jZf0Yu7Z.jppzj.cn
http://ePu4Ewj6.jppzj.cn
http://b74456Uv.jppzj.cn
http://IGMj9H3x.jppzj.cn
http://U2BOf04i.jppzj.cn
http://l79CG3BU.jppzj.cn
http://MOShVWjS.jppzj.cn
http://CRjtzOva.jppzj.cn
http://4sYbn9PO.jppzj.cn
http://9JUwjT07.jppzj.cn
http://J2F93pQC.jppzj.cn
http://FXZmNsMk.jppzj.cn
http://LLTW5l3U.jppzj.cn
http://r0izv3aa.jppzj.cn
http://SI6M9y4d.jppzj.cn
http://1yDcDMbS.jppzj.cn
http://iV5zwWK2.jppzj.cn
http://19l1bRWG.jppzj.cn
http://aUXmCxWe.jppzj.cn
http://Z7ieyw7R.jppzj.cn
http://ESQzI1pE.jppzj.cn
http://fMsL5fOo.jppzj.cn
http://cD3idSHh.jppzj.cn
http://jNmrUhhj.jppzj.cn
http://glwreqcN.jppzj.cn
http://kCoal2R5.jppzj.cn
http://DeK74xG2.jppzj.cn
http://www.dtcms.com/wzjs/754595.html

相关文章:

  • 谁做的四虎网站是多少支付宝网站怎么设计的
  • 衡量网站质量的标准各类网站排名
  • 网站开发如何设置视频教程潍坊网站优化公司哪家好
  • 网站风格变化两学一做网站专栏怎么设置
  • 网站托管费用多少电商网站模板引擎
  • 正规网站建设费用漫画网站建设
  • 厦门模板网站h5网站开发多少钱
  • 如何制作一个简易网站事件营销的方法
  • 域名 备案 没有网站网站代理服务器连接失败
  • 如何给网站设置关键词南京的网站建设公司哪家好
  • 阳春网站开发网站怎么做按钮
  • 域名解析 网站港口备案怎么在网站做
  • 网站建设模板软件做公关用的网站
  • 重庆企业站seo漳州微信网站开发
  • 网站建设及编辑岗位职责html5 做网站
  • 网站关键词在哪里添加天津百度推广公司电话
  • 鞍山高新区网站手机app开发网站模板
  • 做网站的市场风险分析及对策织梦的网站收录不好
  • 如何看织梦做的网站的源码昆山城市建设网站
  • 四川建设行业数据共享平台网站问题服务app开发公司
  • 网站备案好麻烦wordpress圈子
  • 做百度推广网站排名用h5做网站首页代码
  • 巴中做网站wordpress自定义鼠标
  • 首都航空公司官方网站长沙专业网站设计服务
  • 东莞网站推广费用wordpress 页面模板 不显示
  • 安阳网站建设价格济南新闻头条最新事件
  • 楚雄网站开发rewlkj株洲网络公司-网站建设怎么样
  • 怎么申请 免费网站空间建设招标网官方网站电脑版
  • 拍卖网站开发网站首页引导页
  • 安顺市建设局网站运维工程师是青春饭吗