vue3子组件改变父组件的值(props)reactive和ref的区别及说明

 更新时间:2025年05月06日 11:18:43   作者:Lysun001  
这篇文章主要介绍了vue3子组件改变父组件的值(props)reactive和ref的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

vue3子组件改变父组件的值(props)reactive和ref区别

其实关于子组件改变父组件的值,直接改是不可以的,我们一般通过绑定事件来改变,但是如果是reactive里面的复杂数据类型,我们只要不改变其内存地址,是可以改变复杂数据类型里面的值的

下面看相关代码,父子组件的层级如图

父组件代码

<template>
  <h1>ref定义的值{{refNum}}</h1>
  <h1>reactive定义的值{{reactiveNum}}</h1>
  <h1>reactive定义的数组{{reactiveArr}}</h1>
  <little
    :refNum="refNum"
    :reactiveNum="reactiveNum"
    :reactiveArr="reactiveArr"
  ></little>
</template>

<script>
import little from './little'
import { toRefs, reactive, ref } from 'vue'
export default {
  name: "big",
  components: { little },
  setup () {
    const refNum = ref(0)// 不能直接通过子组件改变
    const reactiveObj = reactive({
      reactiveNum: 0,  // 不能直接通过子组件改变
      reactiveArr: [1, 2, 3]  // 不改变内存地址,可以通过子组件之间改变里面的值
    })
    return {
      refNum,
      ...toRefs(reactiveObj)
    }
  }
}
</script>

<style>
</style>

子组件

<template>
  <button @click="changeRefVal">点我改变ref的值</button>
  &nbsp;&nbsp;
  <button @click="changeReactiveVal">点我改变reactive的值</button>
  &nbsp;&nbsp;
  <button @click="changeReactiveArr">点我改变reactive的数组</button>
</template>

<script>
export default {
  name: "little",
  props: ["refNum", "reactiveNum", "reactiveArr"],
  setup (props, context) {
    // 改变 ref 的值
    const changeRefVal = () => {
      props.refNum++ // 报警告,不生效
    }
    // 改变 reactive 里面的值
    const changeReactiveVal = () => {
      props.reactiveNum++ // 报警告,不生效
    }
    // 改变 reactive 里面的数组
    const changeReactiveArr = () => {
      //   props.reactiveArr = [1, 2, 3, 4]  // 报警告,不生效
      props.reactiveArr.push(4) // 生效
    }
    return {
      changeRefVal,
      changeReactiveVal,
      changeReactiveArr
    }
  },
}
</script>

<style>
</style>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue.js实现可配置的登录表单代码详解

    Vue.js实现可配置的登录表单代码详解

    这篇文章主要介绍了Vue.js实现可配置的登录表单实例代码详解,文中给大家补充介绍了vue.js 全选与取消全选的实例代码,需要的朋友可以参考下
    2018-03-03
  • 在Vue-cli里应用Vuex的state和mutations方法

    在Vue-cli里应用Vuex的state和mutations方法

    今天小编就为大家分享一篇在Vue-cli里应用Vuex的state和mutations方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • vuex分模块后,实现获取state的值

    vuex分模块后,实现获取state的值

    这篇文章主要介绍了vuex分模块后,实现获取state的值,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • 一份超级详细的Vue-cli3.0使用教程【推荐】

    一份超级详细的Vue-cli3.0使用教程【推荐】

    这篇文章主要介绍了一份超级详细的Vue-cli3.0使用教程,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-11-11
  • vue引入Excel表格插件的方法

    vue引入Excel表格插件的方法

    这篇文章主要为大家详细介绍了vue引入Excel表格插件的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • Vue-Cli配置代理转发解决跨域问题的方法

    Vue-Cli配置代理转发解决跨域问题的方法

    本文主要介绍了Vue-Cli配置代理转发解决跨域问题的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • vue使用Proxy实现双向绑定的方法示例

    vue使用Proxy实现双向绑定的方法示例

    这篇文章主要介绍了vue使用Proxy实现双向绑定的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-03-03
  • vue elementui简易侧拉栏的使用小结

    vue elementui简易侧拉栏的使用小结

    这篇文章主要介绍了vue elementui简易侧拉栏的使用,增加了侧拉栏,目的是可以选择多条数据展示数据,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • 解决vue-cli webpack打包开启Gzip 报错问题

    解决vue-cli webpack打包开启Gzip 报错问题

    这篇文章主要介绍了vue-cli webpack打包开启Gzip 报错问题的解决方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • vue深入解析之render function code详解

    vue深入解析之render function code详解

    vue对大家来说应该再熟悉不过了,下面这篇文章主要给大家深入的解析了vue之render function code的相关资料,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-07-07

最新评论