news 2026/7/2 0:12:43

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/6/28 19:09:11

在echarts图表上Y轴上面在各加两种类型并且每个上面分别有两条固定值的的且颜色相同的线

在echarts图表上Y轴上面在各加两种类型并且每个上面分别有两条固定值的的且颜色相同的线 在ECharts中为Y轴添加固定值的参考线&#xff0c;可以通过配置 markLine 来实现。下面是一个清晰的配置示例和说明&#xff0c;可以帮助你快速实现需求。配置项说明示例值series[i].markL…

作者头像 李华
网站建设 2026/7/1 19:15:17

USB转485驱动与Modbus RTU协议时序匹配详解

USB转485通信为何总丢包&#xff1f;Modbus RTU时序匹配的深层真相你有没有遇到过这样的场景&#xff1a;工控机通过USB转485适配器连接几个电表&#xff0c;程序能正常发送Modbus请求帧&#xff0c;但从站就是不回&#xff1f;或者偶尔收到数据&#xff0c;还总是CRC校验失败。…

作者头像 李华
网站建设 2026/6/26 13:37:51

LTspice仿真收敛问题解决方法通俗解释

让LTspice不再“卡住”&#xff1a;仿真不收敛的真相与实战破解你有没有遇到过这样的场景&#xff1f;精心搭好一个Buck电路&#xff0c;信心满满点下运行&#xff0c;结果仿真跑到一半突然不动了——波形停在某个时间点&#xff0c;状态栏显示“Running…”却再无进展。或者弹…

作者头像 李华
网站建设 2026/6/26 11:29:40

苹果再次证明谁才是遥遥领先,iPhone17重夺第一!

之前有国产手机说48周、49周超越了苹果&#xff0c;然而正如另一家国产手机品牌那样&#xff0c;这回事需要讲究耐力的&#xff0c;如今第50周的销量来了&#xff0c;iPhone17重夺国内手机销量第一名&#xff0c;并且领先优势非常明显&#xff0c;证明了iPhone17的吸引力。第50…

作者头像 李华
网站建设 2026/6/30 14:56:57

门电路输入漏电流影响:通俗解释高阻态稳定性

门电路输入漏电流如何“悄悄”破坏高阻态&#xff1f;一个被低估的硬件陷阱你有没有遇到过这样的情况&#xff1a;I2C 总线在低温下工作正常&#xff0c;一到高温就频繁通信失败&#xff1f;某个 GPIO 引脚明明没接任何信号&#xff0c;读出来却是忽高忽低&#xff1f;系统休眠…

作者头像 李华