首页 > web前端 > Vue.js > 正文

Vue3中的setup语法糖、computed函数、watch函数如何用

王林
发布: 2023-05-17 11:58:06
转载
3423人浏览过

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>
登录后复制
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;"><template> <div> <button @click=&quot;hello&quot;>hello</button> </div> </template> <script setup> const hello = () => { console.log('hi') } </script></pre>
登录后复制
</div><p>上面是我们使用setup语法糖后的代码效果,功能实现上是一样的;在 script setup 的标签中,所有的数据、函数可以直接在模板中使用!</p> <p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p> <blockquote>在 script setup 中的顶层变量都可以直接在模板中使用</blockquote> <h3><strong>computed函数</strong></h3> <p>computed 函数的使用:其实我们什么情况下会使用计算属性呢,那一定是通过依赖的数据得到新的数据!</p> <p>1)从Vue中引入computed<br> 2)在setup中进行使用,将一个函数,函数的返回值就是计算好的数据<br> 3)最后呢通过setup返回出去,模板进行使用,如果使用setup语法糖后其实不需要这一步了</p> <p>我们可以举一个简单的例子,比如我们定义一个成绩数字,单纯的分数信息,那我们通过 computed 函数来为我们计算出超过60份的及格成绩;我们就直接使用 script setup 的方式来编码了哈!</p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;"><template> <div> <p>成绩单</p> <a v-for=&quot;num in achievement&quot;> {{ num }} / </a> <p>及格成绩单</p> <a v-for=&quot;num in passList&quot;> {{ 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></pre>
登录后复制
</div><p><img src="https://img.php.cn/upload/article/000/465/014/168429588769802.jpg" alt="Vue3中的setup语法糖、computed函数、watch函数如何用"></p> <h3><strong>watch 函数</strong></h3> <p>跟computed函数一样,watch函数也是组合式API中的一员,watch其实就是监听数据变化的函数,那么在Vue3中它都有哪些用法呢?可以使用watch监听一个或者多个响应式数据,可以使用watch监听响应式数据中的一个属性(简单数据 or 复杂数据)可以配置深度监听,也可以使用watch监听实现默认执行;我们来分开尝试一下代码的写法</p> <p><strong>通过watch监听一个数据</strong> </p> <blockquote><p>watcha监听一个数据,函数两个参数:第一个要监听的数据,第二个参数是监听值发生变化后触发的回调函数,其中回调函数也有两个参数 新值、老值</p></blockquote><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;"><template> <div> 总赞数:{{ num }} <button @click=&quot;num++&quot;>点赞</button> </div> </template> <script setup> import { ref, watch } from 'vue'; //创建一个响应式数据,我们通过点赞按钮改变num的值 const num = ref(0) watch(num, (nv, ov) => { console.log(nv, ov) }) </script></pre>
登录后复制
</div><p><img src="https://img.php.cn/upload/article/000/465/014/168429588821279.jpg" alt="Vue3中的setup语法糖、computed函数、watch函数如何用"></p> <div class="aritcle_card"> <a class="aritcle_card_img" href="/ai/1298"> <img src="https://img.php.cn/upload/ai_manual/000/000/000/175680203955338.png" alt="法语写作助手"> </a> <div class="aritcle_card_info"> <a href="/ai/1298">法语写作助手</a> <p>法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。</p> <div class=""> <img src="/static/images/card_xiazai.png" alt="法语写作助手"> <span>31</span> </div> </div> <a href="/ai/1298" class="aritcle_card_btn"> <span>查看详情</span> <img src="/static/images/cardxiayige-3.png" alt="法语写作助手"> </a> </div> <p><strong>通过watch监听多个数据</strong> </p> <blockquote><p>watcha监听多个数据,例如下面的我们需要监听num和user对象的变化,函数两个参数:第一个要监听的数据(因为是多个数据所以用数组),第二个参数是监听值发生变化后触发的回调函数。</p></blockquote><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;"><template> <div> 总赞数:{{ num }} <button @click=&quot;num++&quot;>点赞</button> </div> <p>姓名:{{ user.name }}</p> <p>年龄:{{ user.age }}</p> <button @click=&quot;user.age++&quot;>过年啦</button> </template> <script setup> import { ref, watch, reactive } from 'vue'; const num = ref(0) let user = reactive( { name: &quot;几何心凉&quot;, age: 18 } ) watch([num, user], () => { console.log('我监听到了') }) </script></pre>
登录后复制
</div><p><img src="https://img.php.cn/upload/article/000/465/014/168429588859832.jpg" alt="Vue3中的setup语法糖、computed函数、watch函数如何用"></p> <p><strong>通过watch监听对象的一个属性(简单类型)</strong> </p> <blockquote><p>watch监听对象的一个属性并且是简单类型的属性,比如我们监听下面的user中的age值,他是一个简单类型,那我们watch的第一个参数形式需要是将对象属性作为返回值的函数;第二个参数是改变后的回调函数。</p></blockquote><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;"><template> <p>姓名:{{ user.name }}</p> <p>年龄:{{ user.age }}</p> <button @click=&quot;user.age++&quot;>过年啦</button> </template> <script setup> import { ref, watch, reactive } from 'vue'; let user = reactive( { name: &quot;几何心凉&quot;, age: 18 } ) watch(()=>user.age, () => { console.log('我监听到了user.age的变化') }) </script></pre>
登录后复制
</div><p><img src="https://img.php.cn/upload/article/000/465/014/168429588821201.jpg" alt="Vue3中的setup语法糖、computed函数、watch函数如何用"></p> <p><strong>通过watch监听对象的一个属性(复杂类型)</strong> </p> <blockquote><p>watch监听对象的一个属性并且是复杂类型的属性,比如下面的我们要监听user中的info,我们尝试一下改变user中info中的wages值,那我们watch的第一个参数形式需要是将对象属性作为返回值的函数;第二个参数是改变后的回调函数。这时候还需要第三个参数那就是 deep 开启深度监听</p></blockquote><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;"><template> <p>姓名:{{ user.name }}</p> <p>年龄:{{ user.age }}</p> <p>薪资:{{ user.info.wages }}</p> <button @click=&quot;user.age++&quot;>过年啦</button> <button @click=&quot;user.info.wages+=2000&quot;>加薪了</button> </template> <script setup> import { ref, watch, reactive } from 'vue'; let user = reactive( { name: &quot;几何心凉&quot;, age: 18, info:{ wages:20000 } } ) watch(()=>user.info, () => { console.log('我监听到了user.info的变化') },{ deep:true }) </script></pre>
登录后复制
</div><p><img src="https://img.php.cn/upload/article/000/465/014/168429588816908.jpg" alt="Vue3中的setup语法糖、computed函数、watch函数如何用"></p> <p><strong>通过watch监听数据默认执行</strong> </p> <blockquote><p>其实这种情况并不多但是也会遇到这种情况,就是我们在监听数据变化的时候,先默认执行一次;其实就是添加我们的immediate参数为true,我们以最初的num为例哈!</p></blockquote><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;"><template> <div> 总赞数:{{ num }} <button @click=&quot;num++&quot;>点赞</button> </div> </template> <script setup> import { ref, watch, reactive } from 'vue'; const num = ref(0) watch(num, () => { console.log('我打印了') },{ immediate:true }) </script></pre>
登录后复制
</div><p><img src="https://img.php.cn/upload/article/000/465/014/168429588835937.jpg" alt="Vue3中的setup语法糖、computed函数、watch函数如何用"></p>

以上就是Vue3中的setup语法糖、computed函数、watch函数如何用的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:亿速云网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号