七、 组件的生命周期 组建的生命周期主要有创建、挂载、更新和销毁四个 每个部分对应有两个内置函数 在不同的生命周期阶段都可以通过这两个内置函数进行操作 详情介绍可以参考: https://baijiahao.baidu.com/s?id=1668393188098846185&wfr=spider&for=pc
八、 组件之间的数据共享 组件之间的关系主要有 1.父子 2.兄弟 先来说说父子之间的数据传递 父 ->子 父向子传递数据主要通过props自定义属性
比如 父组件
<div>
<Son :num='number'></Son>
</div>
<script>
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收到的数据值”})
|