Vue 组件之间的通信

1、父传子 props

父组件 ==》 <Children :dataInfo="dataInfo" /> 

子组件

普通 ==》 props: ["dataInfo"]

严谨给默认值 ==》
props: {

dataInfo: {

   type: Object,

   default: () => {}
}

动态传值 wacth监听 ==》

在子组件中用watch()监听值的改变,不同的类型的要用不同的监听方法 数组、对象深度监听

watch: {

  string:(newValue,oldValue){ // 一般监听
    console.warn(newValue)
  }

      dataInfo:{  // 深度监听

        handler(newValue, oldValue){

          console.warn(newValue)

        },

        deep: true

      },

    },

2、在父组件中用ref="str" 来声明组件,然后通过this.$refs.str.method()在值改变的地方来调用子组件中的方法

父组件 ==》 <Children ref="children" />

methods: {
  refresh() {
    this.$nextTick(()=> { // 这种方法数据解决不能够及时渲染
       this.$refs.children.init(val)
    })
  }
}

子组件 ==》

methods: {
   init(val) {
       this.$refs.children.init(val)
   }
}

3、子向父组件传值 $emit

字组件 ==》

methods: {

    handleClick(val) {

      this.$emit("handleClick", val)

    }

}

父组件 ==》

<Children @handleClick="childrenClick" />

methods: {

    childrenClick(val) {

      console.log(val,'调用子组件的方法传值')

    }

}

4、vuex 通信

https://blog.csdn.net/c153284575/article/details/103700628

5、event bus通信

https://blog.csdn.net/c153284575/article/details/103700069

6、SessionStorage通信

https://blog.csdn.net/c153284575/article/details/103713192

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小小并不小

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值