vue3 监听

在Vue 3中,监听(watching)是一种重要的响应式功能,用于在数据变化时执行特定的逻辑。在Vue 3中,监听可以通过两种方式实现:

  1. 监听单个响应式数据:
    使用watch选项或者watchEffect函数来监听单个响应式数据的变化。例如:

    import { watch, reactive } from 'vue';
    
    const state = reactive({
        count: 0,
    });
    
    watch(() => state.count, (newValue, oldValue) => {
        console.log(`Count changed from ${oldValue} to ${newValue}`);
    });
    

  2. 这里,watch函数接收两个参数:第一个参数是一个回调函数,返回需要监听的响应式数据;第二个参数是回调函数,用于在数据变化时执行。

  3. 监听多个响应式数据:
    使用watch选项并传入一个对象,可以同时监听多个响应式数据的变化。例如:

    import { watch, reactive } from 'vue';
    
    const state = reactive({
        count: 0,
        message: 'Hello',
    });
    
    watch({
        count: (newValue, oldValue) => {
            console.log(`Count changed from ${oldValue} to ${newValue}`);
        },
        message: (newValue, oldValue) => {
            console.log(`Message changed from ${oldValue} to ${newValue}`);
        },
    });
    

  4. 这里,watch接收一个对象作为参数,对象的每个键是需要监听的响应式数据的名称,值是一个回调函数,用于处理数据变化时的逻辑。

  5. 监听响应式数据和立即执行的watchEffect:
    watchEffect函数用于监听响应式数据的变化,并在初始渲染时立即执行一次。例如:

    import { watchEffect, reactive } from 'vue';
    
    const state = reactive({
        count: 0,
    });
    
    watchEffect(() => {
        console.log(`Count is ${state.count}`);
    });
    

  6. 这里,watchEffect函数接收一个回调函数,函数内部访问的任何响应式数据的变化都会触发重新执行。

  7. 这些方法使得在Vue 3中能够方便地监听和响应数据的变化,从而执行相应的逻辑。

Vue3中,可以通过使用`watch`函数来监听数组的变化Vue3中的`watch`函数可以接收两个参数,第一个参数是要监听数据,第二个参数是回调函数,当数据发生变化时会触发该回调函数。对于数组的监听,可以使用`watch`函数的`deep`选项来进行深度监听,以便捕捉到数组的变化。例如: ```javascript let arr = ref(\[\]); // 定义一个响应式的数组 watch(arr, (value) => { console.log('数组发生变化', value); }, { deep: true }); ``` 在上述代码中,我们使用`ref`函数将数组转换为响应式数据,然后使用`watch`函数监听该数组的变化。当数组发生变化时,回调函数会被触发,并打印出数组的新值。通过设置`deep`选项为`true`,可以实现对数组的深度监听。这样,无论是通过赋值、splice方法还是push方法改变数组,都能够被监听到。 需要注意的是,在Vue3中,监听数组的变化需要使用`ref`函数将数组转换为响应式数据,而不是直接使用普通的数组。这样才能确保数组的变化能够被Vue3监听到。 #### 引用[.reference_title] - *1* [Vue3为何使用Proxy实现数据监听](https://blog.csdn.net/Gary_888/article/details/125860568)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [vue3监听变量(包括对象、数组的特殊用法)](https://blog.csdn.net/qq_39157025/article/details/131048908)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值