VUE3 学习笔记(14):VUE3 组合式API与传统选项式API用法

VUE3相较VUE2的亮点很多,作为后端开发置于前端最大的感受就是组合式API(之前采用的是选项式API);它使得整体更简洁易用,但值得提醒的是官方并未强制要求二选一,尽管如此在同一个项目中还是不要出现两种写法。

选项式API

优点

优点:

.VUE2 写法;学习成本低

.选项式类似树结构,阅读方便

.能基本满足后端开发的常见需求

示例

<template>
  <div class="about">
    <p>{{ msg }}</p>
    <br>
    <p>{{ getMsg }}</p>
    <br>
    <p>{{ user.name }}</p>
    <button @click="setMsg()">配置信息</button>
  </div>
</template>
<script>
export default {
  name: 'About',
  data() {
    return {
      msg: '选项式API',
      isDelete: false,
      user: {
        name: '张三',
        age: 18
      }
    }
  },
  methods: {
    setMsg() {
      this.msg = '配置新信息'
    }
  },
  computed: {
    getMsg() {
      return this.isDelete  ? 'false' : 'true'
    }
  }
}
</script>

组合式API

优点

.基于TS速度更快

.生命周期可以重复使用

.父传子可以直接调用(Provide传 Inject接)

.无须再到对应的事件里写事件,直接写就能直接调用

示例

<template>
  <div>
    <p>获取示例</p>
    <br>
    <p>{{msg}}</p>
    <br>
    <p>{{user.name}}</p>
    <li v-for="item in userList">{{item.name}}</li>
    <br>
    <button @click="setUserName">设置UserName</button>

    <HelloWorld msg="传过来消息了" />
    <p>{{deleteMsg}}</p>

    <br>

  </div>
</template>

<script setup>
//直接引用 ref 相当于单个变量的引用
//reactive 相当于对象引用
//ref 与 reactive 相当于 选项式API中的 data
import {ref,reactive} from "vue";
//引用vue的挂载事件 否则无法定义组件事件
import {onMounted} from "vue";
//父传子使用
import {provide} from "vue";
//启用计算属性
import {computed} from "vue";
import HelloWorld from "@/components/HelloWorld.vue";
  const msg = ref('组合式API')
  const isDelete = ref(false)
  const user = reactive({
    name: '张三',
    age: 18
  })
  const userList = ref([
    {
      name: '张三',
      age: 18
    },
    {
      name: '李四',
      age: 19
    }
  ])
  onMounted(() => {
    console.log('组件挂载')
  })
  //定义组件事件
  function setUserName() {
    user.name = '最新设置UserName'
    msg.value = '最新设置msg'
  }
  //传值
  provide('sendMsg','测试一下传值')
  //计算属性
  const deleteMsg = computed(() => {
    return isDelete.value ? 'false' : 'true'
  })

</script>

子组件

<template>
  <div class="greetings">
    <h1 class="green">{{ msg }}</h1>
    <br>
    <h1 class="green">{{ newMsg }}</h1>
    <br>
    <h1 class="green">{{ getMsg }}</h1>
  </div>
</template>

<script>
// 使用inject进行接收
import {ref,inject} from "vue";

export default {
  props: {
    msg: {
      type: String,
      default: 'Hello World'
    }
  },
  setup(props,ctx) {
    //获取props数据
    const newMsg = ref(props.msg+'666')
    //可以获取上下文对象
    console.log(ctx)
    const getMsg= inject('sendMsg')
    return {
      newMsg,getMsg
    }
  }
}
</script>

效果

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SpringCloud 微服务中网关如何记录请求响应日志?

在基于SpringCloud开发的微服务中&#xff0c;我们一般会选择在网关层记录请求和响应日志&#xff0c;并将其收集到ELK中用作查询和分析。 今天我们就来看看如何实现此功能。 日志实体类 首先我们在网关中定义一个日志实体&#xff0c;用于组装日志对象 Data public class …

U-Net: Convolutional Networks for Biomedical Image Segmentation--论文笔记

U-Net: Convolutional Networks for Biomedical Image Segmentation 资料 1.代码地址 2.论文地址 https://arxiv.org/pdf/1505.04597 3.数据集地址 论文摘要的翻译 人们普遍认为&#xff0c;深度网络的成功训练需要数千个带注释的训练样本。在本文中&#xff0c;我们提出…

“GPT-4o深度解析:技术演进、能力评估与个人体验综述“

文章目录 每日一句正能量前言对比分析模型架构性能应用场景用户体验技术创新社区和生态系统总结 技术能力语言生成能力语言理解能力技术实现总结 个人感受关于GPT-4o的假设性观点&#xff1a;关于当前语言模型的一般性观点&#xff1a; 后记 每日一句正能量 又回到了原点&#…

【前端】display:none和visibility:hidden两者的区别

&#x1f60e; 作者介绍&#xff1a;我是程序员洲洲&#xff0c;一个热爱写作的非著名程序员。CSDN全栈优质领域创作者、华为云博客社区云享专家、阿里云博客社区专家博主。公粽号&#xff1a;洲与AI。 &#x1f913; 欢迎大家关注我的专栏&#xff0c;我将分享Web前后端开发、…

电机行业MES生产管理系统--助力电机企业数字化转型

电机行业 MES 系统是一个综合生产管理系统&#xff0c; 融合了工厂企业必要的销售、 物 流和制造管理等全公司基础业务以及生产计划和现场监测管理。 一、传统机电行业的管理难题&#xff1a; 1、 产品标准化程度较低&#xff0c; 制造工艺复杂&#xff0c; 生产周期较长&#…

day50 动态规划 198.打家劫舍 213.打家劫舍II 337.打家劫舍III

198.打家劫舍 当前房屋偷与不偷取决于 前一个房屋和前两个房屋是否被偷了。 动规五部曲 1.确定dp数组&#xff08;dp table&#xff09;以及下标的含义 dp[i]&#xff1a;考虑下标i&#xff08;包括i&#xff09;以内的房屋&#xff0c;最多可以偷窃的金额为dp[i]。 2.确…

结构体+结构体内存对齐+结构体实现位段

结构体内存对齐实现位段 一.结构体1.结构体的声明2.结构体变量成员访问操作符3.结构体传参4.匿名结构体5.结构的自引用 二.结构体内存对齐1.对齐规则2.为什么存在内存对齐&#xff1f;3.修改默认对齐数 三.结构体实现位段1.什么是位段2.位段的内存分配3.位段的跨平台问题4.位段…

SELinux深度解析:安全增强型Linux的探索与应用(上)

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《Linux &#xff1a;从菜鸟到飞鸟的逆袭》&#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、引言 1、SELinux概述 2、SELinux诞生背景 3、SELinux …

Django 视图探秘:FBV与CBV注册方式的异同,揭秘as_view()的执行魔法

文章目录 一、FBV、CBV注册方式及其区别FBVCBV 二、as_view()函数查看对应的view函数具体内容&#xff0c;最终返回的是dispatch方法查看dispatch方法 一、FBV、CBV注册方式及其区别 FBV FBV&#xff1a;path(index/,views.index) 通过调用函数方式&#xff0c;views.index是一…

打印机扫描工具V2.1发布

打印机扫描工具V2.1发布 从打印机扫描工具发布1.4版本以来&#xff0c;大家反馈了一些问题&#xff0c;目前就比较集中的问题&#xff0c;做了一些优化&#xff0c;做了一些大的调整&#xff0c;发布了2.1版本。 优化问题&#xff1a; 进一步优化安装包太大问题&#xff0c;…

上海亚商投顾:深成指、创业板指均涨超1%,电力股午后集体走强

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 沪指昨日低开后震荡反弹&#xff0c;深成指、创业板指均涨超1%&#xff0c;黄白二线依旧分化。电力、电网股午…

CHATGPT升级plus(已有账号前提下)

注册wildcard(虚拟卡) 注册号账号后先进行充值&#xff0c;充值后选择CHATGPT一键升级按照他的流程来即可 Wildcard网址&#xff1a;Wildcard跳转注册 填写邀请码充值时少两美金合计14&#xffe5; 邀请码&#xff1a;OL3QXTRH

挑战你的数据结构技能:复习题来袭【6】

1. (单选题)设无向图的顶点个数为n,则该图最多有&#xff08;&#xff09;条边 A. n-1 B. n(n-1)/2 C. n(n1)/2 D. 0 答案&#xff1a;B 分析&#xff1a; 2. (单选题)含有n个顶点的连通无向图,其边的个数至少为()。 A. n-1 B. n C. n1 D. nlog2n 答案&#xff1a;A…

10 数据封装与层次对应关系

一、TCP/IP模型 二、封装与解封装 &#xff08;一&#xff09;数据的封装 &#xff08;二&#xff09;数据的解封装 三、协议、数据与设备 &#xff08;一&#xff09;对应层次协议 结构协议应用层HTTP / FTP / TFTP / SMTP / SNMP/ DNS传输层TCP / UDP网络层ICMP / IGMP / …

使用记事本或者写字板打开中文乱码问题

最近下载一个开源的公共的文件&#xff0c;下载下来是xml格式的文本文件&#xff0c;然后我尝试打开&#xff0c;使用记事本打开文件&#xff0c;内容显示正常&#xff0c;但是因为是xml文件&#xff0c;使用记事本打开的时候没有换行&#xff0c;不方便看&#xff0c;然后就使…

信息系统项目管理师0143:过程概述(9项目范围管理—9.2项目范围管理过程—9.2.1过程概述)

点击查看专栏目录 文章目录 9.2 项目范围管理过程9.2.1 过程概述 9.2 项目范围管理过程 9.2.1 过程概述 项目范围管理过程包括&#xff1a; 规划范围管理&#xff1a;为了记录如何定义、确认和控制项目范围及产品范围&#xff0c;创建范围管理计划。收集需求&#xff1a;为了…

文章自动排版

文字太多了不想看怎么办&#xff1f;想快速提取并罗列文章的重点要如何操作&#xff1f;今天给大家介绍一下如何把复杂的文章总结为一个个观点 使用说明 打开智游剪辑&#xff08;zyjj.cc&#xff09;&#xff0c;搜索文字排版 我们输入要排版的文章&#xff0c;点击立即生成就…

心链9----组队功能开发以及请求参数包装类和包装类实现

心链 — 伙伴匹配系统 组队功能开发 需求分析 理想的应用场景 我要跟别人一起参加竞赛或者做项目&#xff0c;可以发起队伍或者加入别人的队伍 用户可以 创建 一个队伍&#xff0c;设置队伍的人数、队伍名称&#xff08;标题&#xff09;、描述、超时时间 P0 队长、剩余的人数…

安防综合管理系统EasyCVR视频汇聚平台GA/T 1400协议中的关键消息交互示例

在当今的信息化时代&#xff0c;公共安全防范日益成为保障社会和谐稳定的关键。视频监控系统作为现代安全防范的重要手段&#xff0c;正不断在公安、交通、城市管理等领域发挥着越来越重要的作用。而GA/T 1400协议视图库&#xff0c;作为公安视频图像信息应用系统的标准&#x…

使用 TinyEngine 低代码引擎实现三方物料集成

本文由体验技术团队 TinyEngine 项目成员炽凌创作&#xff0c;欢迎大家实操体验&#xff0c;本体验内容基于 TinyEngine 低代码引擎提供的环境&#xff0c;介绍了如何通过 TinyEngine 低代码引擎实现三方物料集成&#xff0c;帮助开发者快速开发。 知识背景 1.1 TinyEngine 低…