广告
返回顶部
首页 > 资讯 > 精选 >Vue3中的setup语法糖、computed函数、watch函数怎么使用
  • 254
分享到

Vue3中的setup语法糖、computed函数、watch函数怎么使用

2023-07-05 08:07:36 254人浏览 安东尼
摘要

这篇文章主要介绍“vue3中的setup语法糖、computed函数、watch函数怎么使用”,在日常操作中,相信很多人在Vue3中的setup语法糖、computed函数、watch函数怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简

这篇文章主要介绍“vue3中的setup语法糖、computed函数、watch函数怎么使用”,在日常操作中,相信很多人在Vue3中的setup语法糖、computed函数、watch函数怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue3中的setup语法糖、computed函数、watch函数怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

setup 语法糖

Vue3中的setup语法糖、computed函数、watch函数怎么使用

大家发现没有,在我们前面几篇文章中的案例代码中,每个案例的模板中都有一些雷同代码,这些代码就是我们的setup函数,但是作为组合api的入口函数,我们所有的组合式API都要写到里面,难道我们每次都要写上这一坨么,其实在Vue中提供了setup 的语法糖,语法糖大家都知道是什么嘛?就比如我们Vue2中的 v-model 不就是语法糖么,可以通过这样一个指令省去了大量的双向数据绑定的代码!那我们来看一下我们的setup都够简化成为什么样子,以下面代码为例,我们声明一个函数,点击按钮触发喊出打印 hi 这样一个简单的效果;

<template>    <div>        <button @click="hello">hello</button>    </div></template><script>export default {    setup() {        const hello = () => {            console.log('hi')        }        return { hello }    }}</script>
<template>    <div>        <button @click="hello">hello</button>    </div></template><script setup>const hello = () => {    console.log('hi')}</script>

上面是我们使用setup语法糖后的代码效果,功能实现上是一样的;在 script setup 的标签中,所有的数据、函数可以直接在模板中使用

在 script setup 中的顶层变量都可以直接在模板中使用

 computed函数

computed 函数的使用:其实我们什么情况下会使用计算属性呢,那一定是通过依赖的数据得到新的数据!

1)从Vue中引入computed
2)在setup中进行使用,将一个函数,函数的返回值就是计算好的数据
3)最后呢通过setup返回出去,模板进行使用,如果使用setup语法糖后其实不需要这一步了

我们可以举一个简单的例子,比如我们定义一个成绩数字,单纯的分数信息,那我们通过 computed 函数来为我们计算出超过60份的及格成绩;我们就直接使用 script setup 的方式来编码了哈!

<template>    <div>        <p>成绩单</p>        <a v-for="num in achievement"> {{ num }} / </a>        <p>及格成绩单</p>        <a v-for="num in passList"> {{ num }} / </a>    </div></template><script setup>import { computed, ref } from 'vue';const achievement = ref([44, 22, 66, 77, 99, 88, 70, 21])const passList = computed(() => {    return achievement.value.filter(item => item > 60)})</script>

Vue3中的setup语法糖、computed函数、watch函数怎么使用

watch 函数

跟computed函数一样,watch函数也是组合式API中的一员,watch其实就是监听数据变化的函数,那么在Vue3中它都有哪些用法呢?可以使用watch监听一个或者多个响应式数据,可以使用watch监听响应式数据中的一个属性(简单数据 or 复杂数据)可以配置深度监听,也可以使用watch监听实现默认执行;我们来分开尝试一下代码的写法

通过watch监听一个数据

watcha监听一个数据,函数两个参数:第一个要监听的数据,第二个参数是监听值发生变化后触发的回调函数,其中回调函数也有两个参数 新值、老值

<template>    <div>        总赞数:{{ num }} <button @click="num++">点赞</button>    </div></template><script setup>import { ref, watch } from 'vue';//创建一个响应式数据,我们通过点赞按钮改变num的值const num = ref(0)watch(num, (nv, ov) => {    console.log(nv, ov)})</script>

Vue3中的setup语法糖、computed函数、watch函数怎么使用

通过watch监听多个数据

watcha监听多个数据,例如下面的我们需要监听num和user对象的变化,函数两个参数:第一个要监听的数据(因为是多个数据所以用数组),第二个参数是监听值发生变化后触发的回调函数。

<template>    <div>        总赞数:{{ num }} <button @click="num++">点赞</button>    </div>    <p>姓名:{{ user.name }}</p>    <p>年龄:{{ user.age }}</p>    <button @click="user.age++">过年啦</button></template><script setup>import { ref, watch, Reactive } from 'vue';const num = ref(0)let user = reactive(    {        name: "几何心凉",        age: 18    })watch([num, user], () => {    console.log('我监听到了')})</script>

Vue3中的setup语法糖、computed函数、watch函数怎么使用

通过watch监听对象的一个属性(简单类型)

watch监听对象的一个属性并且是简单类型的属性,比如我们监听下面的user中的age值,他是一个简单类型,那我们watch的第一个参数形式需要是将对象属性作为返回值的函数;第二个参数是改变后的回调函数。

<template>    <p>姓名:{{ user.name }}</p>    <p>年龄:{{ user.age }}</p>    <button @click="user.age++">过年啦</button></template><script setup>import { ref, watch, reactive } from 'vue';let user = reactive(    {        name: "几何心凉",        age: 18    })watch(()=>user.age, () => {    console.log('我监听到了user.age的变化')})</script>

Vue3中的setup语法糖、computed函数、watch函数怎么使用

通过watch监听对象的一个属性(复杂类型)

watch监听对象的一个属性并且是复杂类型的属性,比如下面的我们要监听user中的info,我们尝试一下改变user中info中的wages值,那我们watch的第一个参数形式需要是将对象属性作为返回值的函数;第二个参数是改变后的回调函数。这时候还需要第三个参数那就是 deep 开启深度监听

<template>    <p>姓名:{{ user.name }}</p>    <p>年龄:{{ user.age }}</p>    <p>薪资:{{ user.info.wages }}</p>    <button @click="user.age++">过年啦</button>    <button @click="user.info.wages+=2000">加薪了</button></template><script setup>import { ref, watch, reactive } from 'vue';let user = reactive(    {        name: "几何心凉",        age: 18,        info:{            wages:20000        }    })watch(()=>user.info, () => {    console.log('我监听到了user.info的变化')},{    deep:true})</script>

Vue3中的setup语法糖、computed函数、watch函数怎么使用

通过watch监听数据默认执行

其实这种情况并不多但是也会遇到这种情况,就是我们在监听数据变化的时候,先默认执行一次;其实就是添加我们的immediate参数为true,我们以最初的num为例哈!

<template>    <div>        总赞数:{{ num }} <button @click="num++">点赞</button>    </div></template><script setup>import { ref, watch, reactive } from 'vue';const num = ref(0)watch(num, () => {    console.log('我打印了')},{    immediate:true})</script>

Vue3中的setup语法糖、computed函数、watch函数怎么使用

到此,关于“Vue3中的setup语法糖、computed函数、watch函数怎么使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: Vue3中的setup语法糖、computed函数、watch函数怎么使用

本文链接: https://www.lsjlt.com/news/350440.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vue3中的setup语法糖、computed函数、watch函数怎么使用
    这篇文章主要介绍“Vue3中的setup语法糖、computed函数、watch函数怎么使用”,在日常操作中,相信很多人在Vue3中的setup语法糖、computed函数、watch函数怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简...
    99+
    2023-07-05
  • Vue3中的setup语法糖、computed函数、watch函数详解
    目录 写在前面 setup 语法糖 computed函数 watch 函数 写在最后 写在前面 专栏介绍:凉哥作为 Vue 的忠实 粉丝输出过大量的 Vue 文章,应粉丝要求开始更新...
    99+
    2023-03-01
    Vue3 setup语法糖 Vue3  computed函数 Vue3  watch函数
  • 详解Vue3中的setup语法糖、computed函数、watch函数
    computed函数在上篇文章中我们学了两个组合式API分别是 ref 和 reactive,现在呢我们学习cmputed函数,相信大家一定知道他即使我们的计算数据定义函数,之前呢是 computed 选项,现在是computed函数;我们...
    99+
    2023-05-14
    setup computed watch vue3
  • Vue3中的setup语法糖、computed函数、watch函数如何用
    computed函数computed 函数的使用:其实我们什么情况下会使用计算属性呢,那一定是通过依赖的数据得到新的数据!1)从Vue中引入computed 2)在setup中进行使用,将一个函数,函数的返回值就是计算好的数据 3)最后呢通...
    99+
    2023-05-17
    Vue3 setup computed
  • Vue3中的script setup语法糖怎么使用
    这篇文章主要介绍了Vue3中的script setup语法糖怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3中的script setup语法糖怎么使用文章都会有所收获,下面我们一起来看看吧。scr...
    99+
    2023-07-04
  • Vue3.2 setup语法糖及Hook函数基本使用
    目录引言setup(语法糖)1、基本使用2、自动注册3、组件通信defineEmit ----> [子组件向父组件事件传递] 代码示列:defineExpose ---->...
    99+
    2022-11-13
  • 怎么在Vue3中使用<script lang=“ts“ setup>语法糖
    迁移组件以下组件有两个道具(要显示的和一个标志)。通过另一个组件,计算模板中显示的小马图像的URL,基于这两个道具。该组件还会在用户单击它时发出一个事件。The image selected while the Ponypony ...
    99+
    2023-05-16
    Vue3 setup
  • vue3中setup()和reactive()函数怎么使用
    <template> <ul> <li v-for="(item, index) in arr" :key="item" @click="...
    99+
    2023-05-19
    Vue3 setup() reactive()
  • vue3中的setup函数如何使用
    这篇文章主要讲解了“vue3中的setup函数如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue3中的setup函数如何使用”吧!概述 一、 初识setup函数 ...
    99+
    2023-06-30
  • 关于vue3中setup函数的使用
    概述  一、 初识setup函数  组件中所用到的:数据、方法等等均要配置在setup中,这也就意味着在Vue2中写的data、methods在这里都不再推荐使...
    99+
    2022-11-13
  • Vue3中SetUp函数的props和context参数怎么用
    第一个参数props:props是一个对象,包含父组件传递给子组件的所有数据。在子组件中使用props进行接收。包含配置声明并传入的所有的属性的对象也就是说:如果你想通过props的方式输出父组件传递给子组件的值。你需要使用props进行接...
    99+
    2023-05-22
    Vue3 setup props
  • 详解vue3中setUp和reactive函数的用法
    1 setUp的执行时机 我们都知道,现在vue3是可以正常去使用methods的。 但是我们却不可以在setUp中去调用methods中的方法。 为什么了??? 我们先了解一下下...
    99+
    2022-11-12
  • 详解Vue3中setup函数的使用教程
    目录vue2 和 vue3 开发的区别使用 setup 原因setup 用法setup 可以接受哪些参数setup 详解setup 函数自动执行setup 函数定义变量setup 创...
    99+
    2022-11-13
  • vue3中setup函数的参数props和context怎么配置
    这篇文章主要介绍了vue3中setup函数的参数props和context怎么配置的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue3中setup函数的参数props和con...
    99+
    2022-10-19
  • vue3组合式API中setup()概念和reactive()函数的用法
    目录⭐一、组合式API对比vue2项目结构在vue2当中在vue3当中⭐二、setup()函数的使用2.1setup()函数的基础概念2.2.setup()初体验2.3.reacti...
    99+
    2023-05-14
    vue3 setup()与reactive()使用 vue3组合式API vue3 setup()
  • Vue中的computed函数怎么使用
    这篇“Vue中的computed函数怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue中的computed函数怎么...
    99+
    2023-07-05
  • vue3组合式API中setup()概念和reactive()函数的用法是什么
    本篇内容主要讲解“vue3组合式API中setup()概念和reactive()函数的用法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue3组合式API中setup()概念和react...
    99+
    2023-07-05
  • Vue3中的h函数怎么使用
    这篇文章主要讲解了“Vue3中的h函数怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue3中的h函数怎么使用”吧!简介众所周知,vue内部构建的其实是虚拟DOM,而虚拟DOM是由虚...
    99+
    2023-07-06
  • javascript之generator生成器函数与asnyc/await语法糖怎么使用
    这篇文章主要讲解了“javascript之generator生成器函数与asnyc/await语法糖怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript之generat...
    99+
    2023-07-05
  • Vue3中toRef和toRefs函数怎么使用
    好,接下来我们使用 toRef 函数写一个案例,还是和以前一样,页面展示一个用户的名称和年纪。<template> <div> <h2>toRef toRefs 函数</h2> ...
    99+
    2023-05-16
    Vue3 toref torefs
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作