Vue2回顾---④

七、
组件的生命周期
组建的生命周期主要有创建、挂载、更新和销毁四个
每个部分对应有两个内置函数
在不同的生命周期阶段都可以通过这两个内置函数进行操作
详情介绍可以参考:
https://baijiahao.baidu.com/s?id=1668393188098846185&wfr=spider&for=pc


八、
组件之间的数据共享
组件之间的关系主要有
1.父子 2.兄弟
先来说说父子之间的数据传递
父 ->子
父向子传递数据主要通过props自定义属性

比如
父组件

<div>
    <Son :num='number'></Son>
</div>

<script>
//components来注册组件
export default{
    components:{
    Son
    }
    data(){
    return{
    number:30
    }
    }
}
</script>

子组件

<div>
    <p>父组件传过来的num为:{{num}}</p>
</div>

<script>
export default{
props['num']
}
</script>

这样父组件就会把30传给子组件的num

子->父
子组件传递数据给父组件需要用到自定义函数
子组件方法:
this.$emit(‘sonnum’,‘snum’)
sonnum是子组件自定义的一个传递名字(相当于snum的一个代号)
snum是子组件中data原来就有的数据名

父组件方法:
调用子组件时 加入属性@sonnum = ‘fathernum’
sonum就是那个规定好的代号
father是父组件data里原有的方法名(相当于把sonmun作为参数传递过来)

fathernum(val){
this.fnum = val
}
fnum是父组件data里的一个数据名
val就是sonnum的值

这样snum的值就传给了fnum

兄弟之间传递
兄弟组件之间的数据传递主要通过eventbus这样一个js文件来作为中间的桥梁
新建一个eventbus.js文件(名字自拟) 然后导入Vue 再实例化一个Vue对象向外导出

发送方A导入eventbus.js 文件
import bus from ‘eventbus.js’
然后通过bus.$emit(‘自定义方法名字’,‘要传递的数据’)

接收方B同样也要导入eventbus.js文件
然后通过bus.$on(‘自定义方法名字’,val =>{“val就是从A收到的数据值”})

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值