温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Vue 组件传值几种常用方法【总结】

发布时间:2020-08-25 18:27:30 来源:脚本之家 阅读:171 作者:紫颖梦忆 栏目:web开发

使用vue也有很多年了,一直都没有整理一下相关知识,给大家总结下开发过程中所遇到的一些坑,主要给大家总结一下vue组件传值的几种常用方法:

1、通过路由带参数传值

   ① A组件通过query把id传给B组件         

 this.$router.push({path:'/B',query:{id:1}})

  ② B组件接收 

 this.$route.query.id

2、父组件向子组件传值

使用props向子组件传递数据

子组件部分:child.vue

 <template> <div> <ul> <li v-for='(item,index) in nameList' :key='index'>{{item.name}}</li> </ul> </div> </template> <script> export default { props:['nameList'] } </script>

父组件部分:

 <template> <div> <div>这是父组件</div> <child :name-list='names'></child> </div> </template> <script> import child from './child.vue' export default { components:{ child }, data(){ return{ names:[ {name:'柯南'}, {name:'小兰'}, {name:'工藤新一'} ] } } } </script>

3、子组件向父组件传值

    子组件主要通过事件向父组件传递数据:

    子组件部分:

 <template> <div> <ul> <li v-for='(item,index) in nameList' :key='index'>{{item.name}}</li> </ul> <Button @click='toParent'>点击我</Button> </div> </template> <script> export default { props:['nameList'], methods:{ toParent(){ this.$emit('emitData',123) } } } </script>

父组件部分:

 <template> <div> <div>这是父组件</div> <child :name-list='names' @emitData='getData'></child> </div> </template> <script> import child from './child.vue' export default { components:{ child }, data(){ return{ names:[ {name:'柯南'}, {name:'小兰'}, {name:'工藤新一'} ] } }, methods:{ getData(data){ console.log(data); //123 } } } </script>

总结

以上所述是小编给大家介绍的Vue 组件传值几种常用方法【总结】,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对亿速云网站的支持!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI