Vue3---基础3(组合式API,setup语法糖)

选项式API与组合式API

        在Vue2内是选项式API(OptionsAPI)

        在Vue3内是组合式API(CompositionAPI)

      选项式API

                示例代码

<script lang="ts">
export default {name: 'person',data() {return {name: "张杰",age: 22,tel: 19821220}},methods: {showTel() {alert(`联系电话:${this.tel}`)},}
}
</script>

        弊端:       

                Options 类型的 API ,数据,方法,计算属性等都是分散在 data,methods。computed中的。新增或者改需求,就要分别修改,不便于维护和复用

        

      组合式API

        优势:

                使用函数的方法,更加优雅的组织代码,相关功能代码更加有序的组织在一起

setup

概念:

        是Vue3中的一个新的配置项,值是一个函数。组件中所用到的数据,方法,计算属性等均配置在 setup

特点:

        setup 函数返回的对象中的内容,可以直接在模版中使用

        setup 中访问的 this 是 undefined

        setup 函数会在 beforeCreate 之前调用,是领先所有钩子执行的

返回值

        可以写成这种对象形式

return {name,age,tel,showTel,changeName,changeAge}

        也可以写成函数形式

return () => {name,age,tel,showTel,changeName,changeAge}

setup 和 OptionsAPI

        在Vue3内,setup 和 data、methods这种选项式api同时存在

        在data内,是可以通过  this 去读取到 setup 内定义的数据,但是在setup内读取不到data内数据

setup语法糖

        使用setup函数需要导出,数据多的情况导出的数据就需要写的很多

        这个时候就可以使用语法糖,写第二个script标签,标签内加上 setup

        这样即使在 script 内写入再多的数据和方法,都不需要return导出了

<script lang="ts">export default {name: 'person',}
</script><script lang="ts" setup>// 数据 此时不为响应式let name = '张杰'let age = 22let tel = 19821220// 方法function showTel() {console.log(tel);alert(`联系电话:${tel}`)}function changeName() {name = 'Jason Zhang'}function changeAge() {age += 1}
</script>

        注意:需要在标签上也写 lang=“ts”,不然会报错

        因为此时写了两个script标签了,第一个标签内就定义了一个名字,如果想省略第一个script,可以按照以下方法实现

        下载扩展包

npm i vite-plugin-vue-setup-extend -D

        在vite.config.ts 文件内  引入下载的包并注册使用

        删除第一个script,在第二个script标签后面可以加name,示例:

<script lang="ts" setup name=“abc123”></script>

        

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/806979.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

白盒测试-条件覆盖

​ 条件覆盖是指运行代码进行测试时&#xff0c;程序中所有判断语句中的条件取值为真值为假的情况都被覆盖到&#xff0c;即每个判断语句的所有条件取真值和假值的情况都至少被经历过一次。 ​ 条件覆盖率的计算方法为&#xff1a;测试时覆盖到的条件语句真、假情况的总数 / 程…

LLM(一):大语言模型

自2022年&#xff0c;ChatGPT发布之后&#xff0c;大语言模型&#xff08;Large Language Model&#xff09;&#xff0c;简称LLM掀起了一波狂潮。作为学习理解LLM的开始&#xff0c;先来整体的理解一下大语言模型 一&#xff0c;发展历史 大语言模型的发展历史可以追溯到早期…

【讲解下目标追踪】

&#x1f308;个人主页: 程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…

【AI 测试】一:算法和数据结构理解

目录 算法和数据结构理解概念及实际列子一、排序算法概念冒泡排序 (Bubble Sort)选择排序 (Selection Sort)插入排序 (Insertion Sort)归并排序 (Merge Sort)快速排序 (Quick Sort)堆排序 (Heap Sort)计数排序 (Counting Sort)桶排序 (Bucket Sort)基数排序 (Radix Sort)二、查…

每日一题——环形链表的约瑟夫问题

题目链接&#xff1a; 环形链表的约瑟夫问题_牛客题霸_牛客网 题目&#xff1a; 描述 编号为 1 到 n 的 n 个人围成一圈。从编号为 1 的人开始报数&#xff0c;报到 m 的人离开。 下一个人继续从 1 开始报数。 n-1 轮结束以后&#xff0c;只剩下一个人&#xff0c;问最后留…

17. 网络编程2

本合集已发布文章 (一)Linux应用编程基本概念 (二)Linux文件I/O基础 (三)Linux标准I/O库

idm线程越多越好吗 idm线程数多少合适 IDM百度云下载 IDM下载器如何修改线程数

IDM&#xff08;Internet Download Manager&#xff09;是一款流行的网络下载器&#xff0c;它支持多线程下载&#xff0c;这意味着它可以同时建立多个连接来下载文件的不同部分&#xff0c;从而提高下载速度。我们在使用IDM的时候总是有很多疑问&#xff0c;今天我们学习IDM线…

【形而上学】数据治理之元数据——用数据的数据管理数据

【形而上学】数据治理之元数据——用数据的数据管理数据 一、都柏林核心元数据元素集二、元数据2.1 什么是元数据2.2 元数据类型2.3 实现元数据的技术 三、元数据相关标准 一、都柏林核心元数据元素集 1995年3月&#xff0c;NCSA与OCLC共同在俄亥俄州都柏林市举行了一次仅有受邀…

Linux命令学习—linux 的常用命令

1.1、改变目录 cd 目录的表达方法&#xff1a; /根目录 .当前目录 .. 上一级目录 ~家目录 #cd / 进入到系统根目录 #cd . 进入当前目录 #cd .. 进入当前目录的父目录&#xff0c;返回上层目录 #cd /tmp 进入指定目录/tmp #cd ~ 进入当前用户的家目录 #cd …

【智能优化算法详解】粒子群算法PSO量子粒子群算法QPSO

1.粒子群算法PSO 博主言简意赅总结-算法思想&#xff1a;大方向下个体自学习探索群体交流共享 对比适应度找到最优点 背景 粒子群算法&#xff0c;也称粒子群优化算法或鸟群觅食算法&#xff08;Particle Swarm Optimization&#xff09;&#xff0c; 缩写为 PSO。粒子群…

Linux:文本编辑器 - vim

Linux&#xff1a;文本编辑器 - vim vim基本操作普通模式模式切换移动光标复制粘贴删除替换撤销 底行模式行号查找 vim基本操作 Vim(Vi Improved)是一款功能强大的文本编辑器&#xff0c;是Unix/Linux系统中广泛使用的编辑器之一。它源于上世纪70年代开发的Vi编辑器&#xff0…

C#学习笔记9:winform上位机与西门子PLC网口通信_上篇

今日继续我的C#学习笔记&#xff0c;今日开始学习打开使用千兆网口来进行与西门子PLC的通信&#xff1a; 文章提供整体代码、解释、测试效果截图、整体测试工程下载&#xff1a; 主要包含的知识有&#xff1a;下载NuGet程序包、西门子PLC及通信协议、搭建虚拟的S7通信仿真环境…

为了进阿里拿Offer,逼得我两个月吃透了这些Java高级面试题解析,终于上岸

JVM与调优 21 题及答案解析 JVM的内存结构。 JVM方法栈的工作过程&#xff0c;方法栈和本地方法栈有什么区别。 JVM的栈中引用如何和堆中的对象产生关联。 可以了解一下逃逸分析技术。 gc的常见算法 CMS以及G1的垃圾回收过程&#xff0c;CMS的各个阶段哪两个是Stop the wo…

前端解决跨域问题

什么是跨域&#xff1f; 跨域是浏览器行为&#xff0c;是浏览器的一种安全策略&#xff1b;由于浏览器 同源策略 导致浏览器访问服务器时被拦截 同源策略&#xff08;Sameoriginpolicy&#xff09;&#xff1a; 是一种约定&#xff0c;它是浏览器最核心也最基本的安全功能&am…

51.网络游戏逆向分析与漏洞攻防-角色管理功能通信分析-角色选择的模拟与截取

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果 内容参考于&#xff1a;如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果&…

制造业、能源等传统行业进行数字化转型时要注意哪些问题?

制造业、能源等传统行业在进行数字化转型时需要注意以下几个关键问题&#xff1a; 1、明确转型目标和战略规划&#xff1a;企业需要根据自身的业务特点、市场需求和长远发展目标&#xff0c;制定清晰的数字化转型战略。包括确定转型的重点领域、预期成果、时间表和资源投入。 …

阿里云云效CI/CD配置

1.NODEJS项目流水线配置(vue举例) nodejs构建配置 官方教程 注意:下图的dist是vue项目打包目录名称,根据实际名称配置 # input your command here cnpm cache clean --force cnpm install cnpm run build 主机部署配置 rm -rf /home/vipcardmall/frontend/ mkdir -p /home/…

计算分数和-第12届蓝桥杯选拔赛Python真题精选

[导读]&#xff1a;超平老师的Scratch蓝桥杯真题解读系列在推出之后&#xff0c;受到了广大老师和家长的好评&#xff0c;非常感谢各位的认可和厚爱。作为回馈&#xff0c;超平老师计划推出《Python蓝桥杯真题解析100讲》&#xff0c;这是解读系列的第48讲。 计算分数和&#…

java并发体系-锁

ReentrantLock ReentrantLock是Java并发编程中的一种锁机制。它的基本流程如下&#xff1a; 创建ReentrantLock对象。在需要加锁的代码块前调用lock()方法&#xff0c;该方法会尝试获取锁&#xff0c;如果锁已被其他线程占用&#xff0c;则当前线程会被阻塞。执行需要加锁的代…

redis架构知识点

Redis 在规模如下&#xff1a; 机器内存总量约70TB&#xff0c;实际使用内存约40TB&#xff1b;平均每秒处理约1500万次请求&#xff0c;峰值每秒约2000万次请求&#xff1b;每天处理约1万亿余次请求&#xff1b;单集群每秒处理最高每秒约400万次请求&#xff1b;集群实例与单机…