news 2026/5/6 23:25:55

vue3的ts页面初始化模板代码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
vue3的ts页面初始化模板代码

vue3的ts页面初始化模板代码

在 Vue 3 中使用 TypeScript 开发时,主要有两种编写页面的方式。以下是两种风格的模板代码,你可以根据项目需求选择使用。

📝 两种页面初始化模板

1. 标准 Composition API 写法

这种写法使用defineComponent和明确的setup函数,结构清晰,适合初学者和需要明确控制暴露内容的情况。

<template><divclass="page-container"><h1>{{pageTitle}}</h1><p>计数器:{{count}}</p><button @click="increment">增加</button><button @click="reset">重置</button></div></template><script lang="ts">import{defineComponent,ref}from'vue';exportdefaultdefineComponent({name:'MyPage',setup(){// 响应式数据constpageTitle=ref<string>('Vue 3 + TypeScript 页面');constcount=ref<number>(0);// 方法constincrement=():void=>{count.value++;};constreset=():void=>{count.value=0;};// 生命周期钩子constinitialize=():void=>{console.log('页面初始化完成');};// 返回模板中需要使用的数据和方法return{pageTitle,count,increment,reset,initialize};},mounted(){this.initialize();}});</script><style scoped>.page-container{padding:20px;max-width:800px;margin:0auto;}</style>

2.<script setup>语法糖写法(推荐)

这种写法更简洁,不需要显式返回数据,适合 Vue 3.2+ 版本,是目前的主流写法。

<template><divclass="page-container"><h1>{{pageTitle}}</h1><p>计数器:{{count}}</p><p>双倍计数:{{doubleCount}}</p><button @click="increment">增加</button><button @click="reset">重置</button></div></template><script setup lang="ts">import{ref,computed,onMounted}from'vue';// 响应式数据constpageTitle=ref<string>('Vue 3 + TypeScript 页面');constcount=ref<number>(0);// 计算属性constdoubleCount=computed(():number=>count.value*2);// 方法constincrement=():void=>{count.value++;};constreset=():void=>{count.value=0;};// 生命周期钩子onMounted(():void=>{console.log('页面初始化完成');initialize();});constinitialize=():void=>{// 初始化逻辑console.log('初始化页面数据');};</script><style scoped>.page-container{padding:20px;max-width:800px;margin:0auto;}button{margin:05px;padding:8px16px;cursor:pointer;}</style>

🔧 高级功能扩展模板

如果需要更复杂的功能,可以参考以下包含路由、状态管理和API调用的完整模板:

<template><divclass="advanced-page"><header><h1>{{pageTitle}}</h1><nav><router-link to="/home">首页</router-link><router-link to="/about">关于</router-link></nav></header><main><div v-if="loading"class="loading">加载中...</div><div v-else><slot name="content"><p>用户数据:{{userData}}</p><button @click="fetchData":disabled="loading">{{loading?'加载中...':'获取数据'}}</button></slot></div></main></div></template><script setup lang="ts">import{ref,computed,onMounted}from'vue';import{useRouter}from'vue-router';// 类型定义interfaceUser{id:number;name:string;email:string;}interfacePageProps{title?:string;}// Props 定义constprops=withDefaults(defineProps<PageProps>(),{title:'默认页面标题'});// 响应式数据constpageTitle=ref<string>(props.title);constloading=ref<boolean>(false);constuserData=ref<User|null>(null);// 计算属性consthasUserData=computed(():boolean=>userData.value!==null);// 方法constfetchData=async():Promise<void>=>{loading.value=true;try{// 模拟 API 调用constresponse=awaitfetch('/api/user');userData.value=awaitresponse.json();}catch(error){console.error('获取数据失败:',error);}finally{loading.value=false;}};// 生命周期onMounted(async():Promise<void>=>{awaitfetchData();});// 暴露给父组件的方法defineExpose({fetchData,resetData:()=>{userData.value=null;}});</script><style scoped>.advanced-page{min-height:100vh;background-color:#f5f5f5;}header{background:#fff;padding:1rem;box-shadow:02px4pxrgba(0,0,0,0.1);}.loading{text-align:center;padding:2rem;color:#666;}button:disabled{opacity:0.6;cursor:not-allowed;}</style>

💡 关键要点说明

  1. 类型安全:TypeScript 提供了完整的类型支持,减少运行时错误 。
  2. 响应式系统:使用refreactive创建响应式数据 。
  3. 组合式函数:可以将逻辑抽离为可复用的组合式函数 。
  4. 生命周期:使用onMountedonUpdated等组合式 API 替代选项式 API 。

🎯 使用建议

  • 简单页面:推荐使用<script setup>语法糖,代码更简洁。
  • 复杂组件:如果需要明确的控制和组织结构,可以使用标准写法。
  • 团队项目:统一代码风格,制定 TypeScript 规范。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/6 23:25:55

实验室环境下Multisim主数据库权限问题全面讲解

实验室环境下Multisim主数据库访问异常&#xff1f;一文彻底解决权限难题 你有没有遇到过这样的场景&#xff1a;学生在实验室打开Multisim&#xff0c;界面卡住几秒后弹出“ 无法打开主数据库 ”的错误提示&#xff0c;元件库一片空白&#xff0c;仿真根本没法进行&#xf…

作者头像 李华
网站建设 2026/4/18 7:17:56

CCS20中数据对齐优化对性能提升的实测报告

数据对齐如何让DSP性能飙升24%&#xff1f;——基于CCS20的真实调优手记你有没有遇到过这样的情况&#xff1a;算法逻辑完全正确&#xff0c;代码跑起来却总是差那么一口气&#xff1f;帧处理时间卡在临界值、DMA偶尔丢包、多核并行后吞吐不升反降……这些问题背后&#xff0c;…

作者头像 李华
网站建设 2026/4/30 3:37:34

LangFlow环保公益活动宣传文案生成

LangFlow&#xff1a;让环保宣传更智能的可视化AI引擎 在一场即将到来的环保公益活动中&#xff0c;团队需要在48小时内产出数十篇风格统一、情感充沛且符合传播规律的宣传文案——涵盖微信推文、短视频脚本、海报标语等多个场景。如果依靠人工撰写&#xff0c;不仅耗时费力&am…

作者头像 李华
网站建设 2026/4/28 20:35:18

Kafka、ActiveMQ、RabbitMQ、RocketMQ对比

四大消息队列深度对比&#xff1a;Kafka、RabbitMQ、ActiveMQ、RocketMQ 一、核心特性总览对比特性维度Apache KafkaRabbitMQApache ActiveMQApache RocketMQ定位分布式流处理平台企业级消息代理传统消息中间件金融级分布式消息设计语言Scala/JavaErlangJavaJava协议支持自定义…

作者头像 李华
网站建设 2026/5/2 7:38:18

LangFlow合同条款审查辅助工具实现

LangFlow合同条款审查辅助工具实现 在企业法务日常工作中&#xff0c;一份数十页的商务合同往往需要数小时的人工逐条审阅——不仅要识别关键条款&#xff0c;还要判断潜在风险、比对标准模板、提出修改建议。这个过程重复性强、容错率低&#xff0c;极易因疲劳导致疏漏。而如今…

作者头像 李华