vue3如何使用watch监听props中的数据

 更新时间:2022年10月12日 10:24:45   作者:没什么丨好说的  
在vue项目中,父子组件数据传递是最常见的场景,但是今天在开发过程中父级数据传递到子组件,控制子组件的显隐,下面这篇文章主要给大家介绍了关于vue3如何使用watch监听props中数据的相关资料,需要的朋友可以参考下

情况一:监听 props 中基本数据类型

父组件中对传入数据的处理

const handleClick = () => {
  testStr.value += 'P'
}

子组件中监听传入的数据

watch(
  () => props.testStr,
  (newVal, oldVal) => {
    console.log('监听基本类型数据testStr')
    console.log('new', newVal)
    console.log('old', oldVal)
  }
)

不能使用

watch(
   props.testStr,
  () => {
    console.log('监听基本类型数据testStr')
  }
)

的形式,要使用 getter 函数返回值的形式才能触发监听

情况二:监听 props 中引用数据类型且父组件不改变地址指向

父组件中对传入数据的处理

const handleClick = () => {
  let name = 'lx'
  let age = 18
  dataList.value.push({
    name: (name += '~'),
    age: (age += 1)
  })
}

子组件中监听传入的数据

watch(props.dataList, (newVal, oldVal) => {
  console.log('监听引用类型数据dataList')
  console.log('new', newVal)
  console.log('old', oldVal)
})

当父组件传入的是引用类型数据,且在父组件中没有改变该数据的引用地址时,在子组件中可以直接监听传入的数据

情况三:监听 props 中引用数据类型且父组件改变地址指向

父组件中对传入数据的处理

const handleClick = () => {
  let name = 'lx'
  let age = 18
  dataList.value=[
  	{
    	name: (name += '~'),
    	age: (age += 1)
  	}
  ]
}

子组件中监听传入的数据

watch(
  () => props.dataList,
  (newVal, oldVal) => {
    console.log('监听引用类型数据dataList')
    console.log('new', newVal)
    console.log('old', oldVal)
  }
)

当父组件传入的是引用类型数据,且在父组件中通过赋值的形式,改变引用数据的引用地址时,在子组件中要使用 getter 函数返回值的形式,才能监听传入的数据

总结

  1. watch监听 props 中的基本类型数据,需要通过 getter 函数返回值的形式(()=>props.xxx)才能监听
  2. watch监听 props 中的引用类型数据,且父组件中没有改变地址指向时,可以直接监听
  3. watch监听 props 中的引用类型数据,且父组件中改变了地址指向时,需要通过 getter 函数返回值的形式(()=>props.xxx)才能监听
  4. 开发情景:要做瀑布流展示

定义变量:const dataList = ref([])

父组件从接口获取第一页数据,将数据存在dataList中:dataList.value = res.data注意:此时,已经改变引用类型数据 dataList 的地址指向

子组件通过watch监听传入的 dataList,并且调用 manageData() 方法处理 props.dataList 的数据结构:

watch(
  () => props.dataList,
  () => {
    console.log('监听引用类型数据dataList')
    manageData()
    ... // 相应逻辑处理
  }
)

注意:此时可以触发监听

用户下拉刷新操作后,继续发送接口,获取第二页,第三页等等后面的数据,父组件通过 push 操作,将获取到的数据 push 进 dataList 中:

for(let item of res.data){
	dataList.value.push(item)
}

注意:此时,虽然父组件传入的 dataList 的值修改了,但是子组件已经不能触发watch及其处理逻辑了
也就是说,manageData() 方法不能调用,没有做到对后续 push 进来的数据进行数据结构的修改,导致页面展示出现问题

解决办法:

一、使用 computed

const dataListTest = computed(() => {
  manageData()
  return props.dataList
})

二、使用 watchEffect

watchEffect(() => {
  manageData()
})

写在最后

最后的瀑布流展示中,我是直接修改了 props 中的数据,虽然从展示来说没有发现什么问题,但是在 Vue 的官网中是这样说的:

PS:本例子使用语法糖 script setup

到此这篇关于vue3如何使用watch监听props中数据的文章就介绍到这了,更多相关vue3监听props数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue3自定义Hooks函数的使用详解

    Vue3自定义Hooks函数的使用详解

    vue3 中的 hooks 就是函数的一种写法,就是将文件的一些单独功能的js代码进行抽离出来进行封装使用,下面我们就来看看vue3中自定义Hooks函数的使用吧
    2023-09-09
  • Vue项目打包编译优化方案

    Vue项目打包编译优化方案

    当一个较复杂的vue项目打包后,文件会非常大,而且访问时资源加载速度很慢,本文介绍了几种措施来优化。
    2020-09-09
  • Vue实现开关按钮拖拽效果

    Vue实现开关按钮拖拽效果

    这篇文章主要为大家详细介绍了Vue实现开关按钮拖拽效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09
  • vscode中开发运行uniapp项目详细步骤

    vscode中开发运行uniapp项目详细步骤

    VSCode作为一个非常强大的代码编辑器,可以集成众多的插件和工具来优化开发效率,这篇文章主要给大家介绍了关于vscode中开发运行uniapp项目的详细步骤,需要的朋友可以参考下
    2023-07-07
  • vue如何根据网站路由判断页面主题色详解

    vue如何根据网站路由判断页面主题色详解

    这篇文章主要给大家介绍了关于vue如何根据网站路由判断页面主题色的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • 一文详解如何创建Vue3项目及组合式API

    一文详解如何创建Vue3项目及组合式API

    Vue3提供了一种组合式API,可以用来构建可复用的组件和应用程序,下面这篇文章主要给大家介绍了关于如何创建Vue3项目及组合式API的相关资料,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • Vue input控件通过value绑定动态属性及修饰符的方法

    Vue input控件通过value绑定动态属性及修饰符的方法

    这篇文章主要介绍了 Vue input控件通过value绑定动态属性及修饰符的方法,需要的朋友可以参考下
    2017-05-05
  • vue实现滚动鼠标滚轮切换页面

    vue实现滚动鼠标滚轮切换页面

    这篇文章主要为大家详细介绍了vue实现滚动鼠标滚轮切换页面,类似于纵向走马灯,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • vue可ctrl,shift多选,可添加标记日历组件详细

    vue可ctrl,shift多选,可添加标记日历组件详细

    这篇文章主要介绍了vue可ctrl,shift多选,可添加标记日历组件详细,文章通过围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • Vue 关于Store的用法小结

    Vue 关于Store的用法小结

    Vue Store是的状态管理模式和库,它提供了一种集中存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化,这篇文章主要介绍了Vue 关于Store的用法,需要的朋友可以参考下
    2024-08-08

最新评论