watch监视-ref基本类型数据

watch监视-ref基本类型数据

watch的使用场景

比如你有一个昵称。当用户修改了自己的昵称,你希望在控制台打出新的昵称,然后向服务器发送请求,更新后台数据,最后需要弹出提示框,告诉用户修改成功了,但是这一系列的操作的前提就是你要知道用户修改了昵称,你要监视用户修改昵称的这个操作;

  • 作用

监听一个或多个数据的变化,并在数据变化时执行特性的副作用;通俗的讲,它就是一个监视器,它的工作就是盯着一个数据,一点数据变化了,它就立即向你汇报,并且执行你交代数据变化后的任务;

使用watch的基本步骤

  • 首先预设一段非常简单的代码,计数器
js 复制代码
<template>
  <div class="person">
    <h2>{{ sum }}</h2>
    <button @click="sumA">点我加1</button>
  </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue';

let sum = ref(0)

function sumA() {
  sum.value += 1  
}

</script>

<style scoped>
  .person{
    background-color: rgb(39, 148, 191);
    padding-left: 50px;
  }
  .btn {
    display: flex;
    gap:20px
  }
</style>
  • 在vue3中,如果我们想要使用watch,先要引入它
js 复制代码
import { ref,watch } from 'vue';
  • 之后我们来监视这个数字的变化
vue 复制代码
watch(sum,(newValue,oldValue) => {
  console.log(`sum发生了变化,原来的值是${oldValue},现在的值是${newValue}`);
})
  • 那如果我们现在有这样的一个需求,当数字加到10的时候,就停止监听
js 复制代码
const watchStop = watch(sum,(newValue,oldValue) => {
  console.log(`sum发生了变化,原来的值是${oldValue},现在的值是${newValue}`);
  console.log(watchStop)
})

这个代码就讲述了watch具有停止监听的能力

js 复制代码
const watchStop = watch(sum,(newValue,oldValue) => {
  console.log(`sum发生了变化,原来的值是${oldValue},现在的值是${newValue}`);
  if(newValue >= 10) {
    watchStop();
  }
})
相关推荐
前端一课几秒前
【vue高频面试题】第 11 题:Vue 的 `nextTick` 是什么?为什么需要它?底层原理是什么?
前端·面试
前端一课1 分钟前
【vue高频面试题】第 10 题:`watch` VS `watchEffect` 的区别是什么?触发时机有什么不同?
前端·面试
h***34636 分钟前
SpringBoot3.3.0集成Knife4j4.5.0实战
android·前端·后端
Yanni4Night6 分钟前
数据可视化神器Heat.js:让你的数据热起来
前端·javascript
Lazy_zheng7 分钟前
前端页面更新检测实战:一次关于「用户不刷新」的需求拉扯战
前端·vue.js·性能优化
前端一课10 分钟前
【vue高频面试题】第9题:Vue3 的响应式原理是什么?和 Vue2 的响应式有什么区别?为什么 Vue3 改用了 Proxy?
前端·面试
Demon--hx10 分钟前
[C++]迭代器失效问题
前端·c++
GISer_Jing11 分钟前
前端架构学习
前端·学习·架构
前端一课12 分钟前
【vue高频面试题】第4题:Vue 3 中的 setup() 是什么?它的执行时机是什么?能做什么?
前端·面试
前端一课12 分钟前
【vue高频面试题】第5题:Vue3 的父子组件通信方式有哪些?分别适用于什么场景?
前端·面试