vue 3 中watch 与 computed 常用方法

export default defineComponent({
  name: 'HeaderForm',
  setup(props, { emit }) {
    const num = ref(0)
    
   const dataRea = reactive({
      periodLists: [],
      form: {
        period: '',
        num: 0
      }
    })
    // 第一种 computed 简单写法
    const newNum = computed(() => {
    	// 注意 ref的值 在 value下
      return num.value + 5
    })
    
    // 第二种 computed 接收一个 set get方法
    const otherNum = computed({
      get: () => {
        return num.value + 8
      },
      set: (parmas) => {
        console.log('====parmas=::', parmas)
        num.value = parmas - 1
      }
    })

    setTimeout(() => {
      otherNum.value = 100
    }, 3000) // 1. 三秒后给 newName 赋值

	// watch 监听一个 ref,单个属性监听
	/**
	* watch 接收三个参数
	* 1、要监听的属性,
	* 2、一个函数,获取新旧 值
	* 3、执行操作的修饰符
	*/ 
    watch(num, (n, o) => {
      console.log('---num--n-: ', n)
      console.log('---num--o-: ', o)
    }, {deep: true, immediate: true})
    
    // watch 监听一个 reactive 下 某个对象的某个属性
    watch(() => dataRea.form.num, (newValue, oldValue) => {
      console.log('form.num =111=newValue--:', newValue)
      console.log('form.num =111=oldValue--:', oldValue)
    })
    // 监听多个 参数, 返回的新旧值 为 多个参数的数组 如:newValu: [0, 23]
    watch([() => dataRea.form.num, num], (newValue, oldValue) => {
      console.log('form.num =22=newValue--:', newValue)
      console.log('form.num =222=oldValue--:', oldValue)
    })

    return {
      ...toRefs(dataRea),
      ...toRefs(myMethods),
      formRef,
      formRule,
      num,
      newNum,
      otherNum
    }
  }
})

WX: xhangxuyang

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刺客-Andy

努力将爱好变成更有价值的事物

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值