Vue3进阶5个小知识点 附带源码

1.在Vue3中,可以使用<script setup>标签来简化组件的编写。在这个标签中,我们可以将数据、方法和其他属性直接放在setup()函数内部,而不需要使用data、methods等选项。这样可以让代码更加简洁和易于阅读。

<template><div>{{ count }}</div>
</template><script setup>
import { ref } from 'vue'const count = ref(0)
</script>

2.使用Composition API
Vue3引入了一种新的API,称为Composition API,它允许我们更好地组织和重用逻辑。Composition API是基于函数的,我们可以创建一些可复用的函数,然后在组件中使用这些函数。这使得代码更加模块化和易于维护。

import { ref, computed } from 'vue'export default {setup() {const count = ref(0)const doubleCount = computed(() => count.value * 2)function increment() {count.value++}return {count,doubleCount,increment,}},
}

3.使用v-model与@update:modelValue结合实现双向绑定
在Vue3中,我们可以使用v-model指令来实现双向绑定。但是,我们需要结合@update:modelValue事件来实现双向绑定。当输入框的值发生变化时,我们需要触发这个事件,并将新的值传递给父组件。

<!-- 子组件 -->
<template><input type="text" :value="modelValue" @input="updateModelValue" />
</template><script setup>
import { defineProps, defineEmits } from 'vue'
import { ref } from 'vue'const props = defineProps({ modelValue: String })
const emit = defineEmits(['update:modelValue'])
const inputValue = ref(props.modelValue)function updateModelValue(event) {inputValue.value = event.target.valueemit('update:modelValue', event.target.value)
}
</script>

4.使用defineExpose暴露组件的方法和属性给父组件使用
在Vue3中,我们可以使用defineExpose来暴露组件的方法和属性给父组件使用。这样可以避免将所有方法和属性都添加到provide/inject系统中,使得代码更加简洁。

import { defineComponent, ref, defineExpose } from 'vue'
import { useMessage } from './useMessage' // 自定义hooksexport default defineComponent({setup() {const message = useMessage() // 调用自定义hooks获取消息提示方法const count = ref(0) // 定义一个响应式变量countconst increment = () => { // 定义一个增加count的方法count.value++message('count已更新') // 调用消息提示方法显示count已更新的信息}const reset = () => { // 定义一个重置count的方法count.value = 0message('count已重置') // 调用消息提示方法显示count已重置的信息}const doubleCount = computed(() => count.value * 2) // 计算count的两倍值的属性doubleCountconst expose = defineExpose({ // 暴露给父组件的方法和属性count,increment,reset,doubleCount,})return expose // 返回暴露给父组件的方法和属性对象},
})

5.使用watchEffect监听响应式变量的变化并执行副作用操作
在Vue3中,我们可以使用watchEffect来监听响应式变量的变化,并在变量发生变化时执行副作用操作。这样可以避免在每个渲染周期中手动检查变量是否发生变化,从而减少不必要的性能开销。

import { watchEffect } from 'vue'
import { ref } from 'vue'
import { useMessage } from './useMessage' // 自定义hooksexport default {setup() {const message = useMessage() // 调用自定义hooks获取消息提示方法const count = ref(0) // 定义一个响应式变量countlet isFirstRender = true // 用于判断是否是第一次渲染的标志位,默认为true,表示是第一次渲染,需要执行副作用操作;否则不执行副作用操作。当isFirstRender变为false时,表示已经执行过副作用操作,后续不再执行。

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

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

相关文章

5种主流API网关技术选型,yyds!

API网关是微服务项目的重要组成部分&#xff0c;今天来聊聊API网关的技术选型&#xff0c;有理论&#xff0c;有实战。 不 BB&#xff0c;上文章目录&#xff1a; 1 API网关基础 1.1 什么是API网关 API网关是一个服务器&#xff0c;是系统的唯一入口。 从面向对象设计的角度…

QLabel(“Find What:“) 是在创建 QLabel 对象时,使用 ““ 符号来指定标签的助记键(Mnemonic Key)、访问键

QLabel("&Find What:") 是在创建 QLabel 对象时&#xff0c;使用 “&” 符号来指定标签的助记键&#xff08;Mnemonic Key&#xff09;。 在 Qt 中&#xff0c;助记键用于提供快捷键访问标签或小部件的功能。通过在标签文本中使用 “&” 符号&#xff0…

docker介绍、部署与常用命令

一、docker 介绍 1、容器&#xff08;Container&#xff09;&#xff1a; (1) 概念&#xff1a; 容器是一种用于运行和部署应用程序的技术。它将应用程序及其所有依赖项&#xff08;例如代码、运行时、系统工具、系统库等&#xff09;打包在一个独立的、可移植的运行环境中&…

Facebook的特点优势

Facebook作为全球最大的社交媒体平台之一&#xff0c;同时也是最受欢迎的社交网站之一&#xff0c;Facebook具有许多独特的特点和优势。本文小编将说一些关于Facebook的特点及优势。 1、全球化 Facebook拥有数十亿的全球用户&#xff0c;覆盖了几乎所有国家和地区。这使得人们…

【深度学习笔记】05 线性回归

线性回归 线性回归基于几个简单的假设&#xff1a; 首先&#xff0c;假设自变量 x \mathbf{x} x和因变量 y y y之间的关系是线性的&#xff0c; 即 y y y可以表示为 x \mathbf{x} x中元素的加权和&#xff0c;这里通常允许包含观测值的一些噪声&#xff1b; 其次&#xff0c;我…

MQTT客户端MQTT.fx 1.7.1下载、安装和界面介绍

MQTT.fx是一款基于Eclipse Paho&#xff0c;使用Java语言编写的MQTT客户端工具。支持通过Topic订阅和发布消息&#xff0c;用来前期和物理云平台调试非常方便。 1.下载 1.1.访问官方下载地址下载&#xff0c;但是下载不到1.7.1版本 1.2.在连接网页末尾点击立即下载&#xff0c;…

代码随想录 452. 用最少数量的箭引爆气球

题目 有一些球形气球贴在一堵用 XY 平面表示的墙面上。墙面上的气球记录在整数数组 points &#xff0c;其中points[i] [xstart, xend] 表示水平直径在 xstart 和 xend之间的气球。你不知道气球的确切 y 坐标。 一支弓箭可以沿着 x 轴从不同点 完全垂直 地射出。在坐标 x 处射…

R语言如何实现多元线性回归

输入数据 先把数据用excel保存为csv格式放在”我的文档”文件夹 打开R软件,不用新建,直接写 回归计算 求三个平方和 置信区间(95%)

STL: 容器适配器stack 与 queue

目录 1.容器适配器 1.1 STL标准库中stack和queue的底层结构 1.2 deque的简单介绍(了解) 1.2.1 deque的原理介绍 1.2.2 deque的缺陷 1.2.3 为什么选择deque作为stack和queue的底层默认容器 2. stack的介绍和使用 2.1 stack的介绍 2.2 stack的使用 2.3 利用deque模拟实现…

【算法】FFT-1(递归实现)(不包括IFFT)

FFT 多项式多项式乘法复数及运算导数泰勒公式及展开式欧拉公式单位根 FFTCode IFFT 多项式 我们从课本中可以知道&#xff0c;一个 n − 1 n-1 n−1 次的多项式可以写成 a 0 a 1 x a 2 x 2 a 3 x 3 ⋯ a n − 1 x n − 1 a_{0}a_{1}xa_{2}x^2a_{3}x^3\dotsa_{n-1}x^{n-…

基于Hadoop架构的多重分布式BP神经网络的短期负荷预测方法

点我完整下载&#xff1a;基于Hadoop架构的多重分布式BP神经网络的短期负荷预测方法.docx 基于Hadoop架构的多重分布式BP神经网络的短期负荷预测方法 "A Short-term Load Forecasting Method based on Multi-distributed BP Neural Network Architecture with Hadoop Fram…

【挑战业余一周拿证】二、在云中计算 - 第 2 节 - Amazon EC2 实例类型

第 2 节 - Amazon EC2 实例类型 如果我们想让企业尽可能高效地运作&#xff0c;那就一定要确保员工的技能组合适合他们的角色&#xff0c;就 像我们的咖啡店有不同类型的员工一样&#xff0c;亚马逊云科技也有不同类型的 EC2 实例。每种实例类型 都归属于一个实例系列&#x…

BUUCTF刷题之路-web-[GXYCTF2019]Ping Ping Ping1

启动环境后&#xff0c;是一个简简单单的页面&#xff1a; 看样子是能够触发远程执行漏洞的。尝试下ping 127.0.0.1&#xff0c;如果有回显说明我们的想法是对的。 最近才学习的nc反弹shell。想着是否能用nc反弹shell的办法。控制服务器然后输出flag呢&#xff1f;于是我测试下…

如何通过nginx进行服务的负载均衡

简单介绍 随着互联网的发展&#xff0c;业务流量越来越大并且业务逻辑也越来越复杂&#xff0c;单台服务器的性能及单点故障问题就凸显出来了&#xff0c;因此需要多台服务器组成应用集群&#xff0c;进行性能的水平扩展以及避免单点故障的出现。应用集群是将同一应用部署到多台…

mysql命令行连接数据库

有时项目连接不上数据库&#xff0c;报错鉴权失败&#xff0c;先用mysql工具连接下&#xff0c;容易发现问题。 直接输入mysql看是否已安装&#xff0c;如果没有就安装下。 # 注&#xff1a;直接mysql就行&#xff0c;不用-cli也不用-client&#xff0c;也不用-server&#xf…

NAS非接入层协议学习(二)

在无线通信网络中 NAS (Non-Access Stratum)做为非接入层是演进分组系统(或5G核心网)中的一组协议。NAS用于在用户设备(UE)和移动管理实体(MME/AMF)之间传送非无线电信令&#xff0c;以实现NR/LTE/E-UTRAN接入。 NAS在协议栈中是控制面的最高层。 NAS协议分组中可以将其分为两…

美化wordpress复制文章内容弹出版权提示框的源码代码

通过SweetAlert美化的提示框 将下面代码添加到当前主题模板函数functions.php文件最后即可&#xff1a; function zm_copyright_tips() { echo <link rel"stylesheet" type"text/css" rel"external nofollow" target"_blank" href…

hive杂谈

数据仓库是一个面向主题的、集成的、非易失的、随时间变化的&#xff0c;用来支持管理人员决策的数据集合&#xff0c;数据仓库中包含了粒度化的企业数据。 数据仓库的主要特征是&#xff1a;主题性、集成性、非易失性、时变性。 数据仓库的体系结构通常包含4个层次&#xff…

在 QDialogButtonBox 类中,ActionRole 是一个枚举值,用于指定按钮的角色(Role)

在 QDialogButtonBox 类中&#xff0c;ActionRole 是一个枚举值&#xff0c;用于指定按钮的角色&#xff08;Role&#xff09;。 ActionRole 定义了不同按钮在对话框按钮盒子中所扮演的角色。每个按钮都可以分配一个特定的角色&#xff0c;以便在对话框中根据其作用进行处理。…

第 373 场 LeetCode 周赛题解

A 循环移位后的矩阵相似检查 模拟 class Solution { public:bool areSimilar(vector<vector<int>> &mat, int k) {int m mat.size(), n mat[0].size();k % n;auto g mat;for (int i 0; i < m; i)if (i & 1)rotate(mat[i].begin(), mat[i].begin() …