Vue-数据传递

Vue.js的强大在于组件化,但组件间的数据传递是个关键问题。本文介绍了5种方式:1)父组件通过props向子组件传值;2)子组件通过自定义事件向父组件传值;3)利用路由params传递数据;4)使用localStorage或sessionStorage存储;5)推荐在复杂应用中采用Vuex进行状态管理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

组件(Component)是Vue.js 最强大的功能。组件可以封装可重用的代码,通过传入对象的不同,实现组件的复用,但组件传值就成为一个需要解决的问题。

1.     父组件向子组件传值

组件实例的作用域是孤立的。这意味着不能在子组件的模板内直接引用父组件的数据。要让子组件使用父组件的数据,我们需要通过子组件的props选项。

子组件


子组件需要从父组件获取 logo 的值,就需要使用 props: ['logo']

父组件


2.     子组件向父组件传值

子组件主要通过事件传递数据给父组件。

子组件


其中 transferUser 是一个自定义的事件,this.username 将通过这个事件传递给父组件 

父组件


getUser 方法中的参数 msg 就是从子组件传递过来的参数 username

3. 路由传值


使用时,在生命周期created赋值。

4.     通过localStorage或者sessionStorage来存储数据


5.     Vuex

在应用复杂时,推荐使用vue官网推荐的vuex

https://vuex.vuejs.org/zh-cn/getting-started.html




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值