浅析vue中computed,method,watch,watchEffect的区别

  • 方法methods只要调用每次都会执行
  • watch(惰性)只有依赖项更新才会执行回调函数,且组件初次渲染不会执行
  • watchEffect:自动追踪依赖变化,只要依赖更新即执行回调函数,且组件初次渲染即执行回调函数
  • computed(惰性): 返回一个只读的ref,具有缓存功能,只有依赖项更新才执行回调函数,且组件初次渲染即执行回调函数
javascript 复制代码
<template>
    <section class="demo-wrap">
        <el-button @click="handleClick">{{ state.count }}</el-button>
        <h1>{{ msg }}</h1>
        <el-button @click="handleNameClick">{{ name }}</el-button>
    </section>
</template>

<script setup>
import { ref, reactive, computed, watch, watchEffect } from 'vue'

const state = reactive({ count: 0 })

const text = ref('i am 20 years old !')

const name = ref('Eason')

// 方法只要调用每次都会执行
const handleClick = () => {
    state.count++
    name.value = `Hello - ${Math.random()}`
    text.value = 'Beijing'
}

const handleNameClick = () => {
    name.value = 'Christina'
    console.log('changed name is: ', name.value)
}

// watch(): 侦听一个或多个响应式数据源,并在数据源变化时调用所给的回调函数
// 需要显示指定要监听的属性,当属性值更新时,执行回调函数
// 可以获取属性原来的值
// 组件初次渲染时不会执行(惰性),只有当监听的值发生改变时,回调函数才会执行
// 如果想要组件第一次渲染时执行回调函数,须添加属性:immediate: true(变为非惰性)
watch(() => state.count, (val, preVal) => {
    console.log('val is :', val)
    console.log('preVal is :', preVal)
})

// 监听ref
watch(text, (val, preVal) => {
    console.log('val is: ', val)
    console.log('preVal is: ', preVal)
})

// 监听多个数据源
watch([text, name], ([text, name], [preText, preName]) => {
    console.log('new val: ', text, name)
    console.log('old val: ', preText, preName)
})

// watchEffect(): 立即运行一个函数,同时响应式地追踪其依赖,并在依赖更改时重新执行。
// watch的副作用形式,不用显示指定要监听的属性
// 只要回调函数体中的变量更新, 就会执行回调函数
// 组件初次渲染时会自动执行
watchEffect(() => {
    // 立即运行
    const changedName = name.value
    console.log(`name has changed to ${changedName}`)
})

// 停止监听
const stop = watchEffect(() => {})
stop()

// 计算属性惰性(缓存功能),只有依赖项发生改变时即执行回调函数
// 依赖项不改变,不会执行回调函数
// 组件初次渲染时就会执行
const msg = computed(() => {
    return text.value.toUpperCase()
})

</script>
相关推荐
军军君0130 分钟前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi9221 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
qq_177767372 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462102 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
wuhen_n2 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon2 小时前
理解vue中的ref
前端·javascript·vue.js
jin1233223 小时前
基于React Native鸿蒙跨平台地址管理是许多电商、外卖、物流等应用的重要功能模块,实现了地址的添加、编辑、删除和设置默认等功能
javascript·react native·react.js·ecmascript·harmonyos
2501_920931704 小时前
React Native鸿蒙跨平台医疗健康类的血压记录,包括收缩压、舒张压、心率、日期、时间、备注和状态
javascript·react native·react.js·ecmascript·harmonyos
橙露4 小时前
React Hooks 深度解析:从基础使用到自定义 Hooks 的封装技巧
javascript·react.js·ecmascript
2501_920931705 小时前
React Native鸿蒙跨平台使用useState管理健康记录和过滤状态,支持多种健康数据类型(血压、体重等)并实现按类型过滤功能
javascript·react native·react.js·ecmascript·harmonyos