vue的组件传值方式

若如初见. 提交于 2020-02-27 16:08:17

1、路由传参
①定义路由时加上参数props: true,在定义路由路径时要留有参数占位符: name『用法: to="'路径/'+value"』
②在跳转到的页面加上参数props:[‘name’]
③在跳转到的页面就获取到了name『用法: js中直接this. name;html中直接插值{{ name}}』

2、父组件向子组件传值
①父组件内设置要传的数据『data(){ id: value}』
②在父组件中引用的子组件上绑定一个自定义属性并把数据绑定在自定义属性上『< myBtn :atrid=‘id’></ mybtn>』
③在子组件添加参数props:[‘atrid’],即可

3、子组件向父组件传值
①由于父组件需要参数,所以在父组件中的标签上定义自定义事件,在事件内部获取参数;『@myEvent=" callback"在callback函数中接收参数』
②在子组件中触发自定义事件,并传参。『this.$ emit(‘父组件中的自定义事件’,参数)』

4、组件之间传值
(1)方法一、
①建立一个公共的通信组件( Vue),需要传值的组件里引入该通信组件
②在一个中绑定一个事件this.on(‘eventname’, this. id)
③在另一个组件中触发事件this.$ emit(‘eventname’,( options)=>{})

(2)方法二、
在本地存储中添加公共数据,可以在两个页面中获取

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!