Vue的组件间传值(包括Vuex)

本文详细介绍了Vue中组件间的通信方式,包括父传子、子传父以及如何通过调用组件方法来传递数据。同时,强调了在复杂数据管理场景下Vuex的重要性,展示了Vuex的state、mutations、actions、getters和modules的基本使用。

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

Vue的传值方式有父传子、子传父还有Vuex。

在不使用Vuex的情况下,组件间传值的方式是通过父传子的方式或者兄弟组件传值。


父传子:

fatherComponent:

<template>
    <div>
        <HELLOWORLD :needData="content"></HELLOWORLD>
    </div>
</template>

<script>
import HELLOWORLD from '../components/HelloWorld.vue'
export default {
    components:{
        HELLOWORLD
    },
    data(){
        return{
            content:"content"
        }
    }
}
</script>

<style lang="less" scoped>

</style>

SonComponent(子组件名称为HELLOWORLD):

<template>
    <div>
        <h1>HELLOWORLD</h1>
    </div>
</template>

<script>
export default {
    props:["needData"],
    data(){
        return{
            H:this.needData,
        }
    },
    mounted(){
        console.log(this.H);
    }
}
</script>

<style lang="less" scoped>

</style>

在这里插入图片描述


子传父:

FatherComponent:

<template>
    <div>
        <HELLOWORLD @sendData="getData"></HELLOWORLD>
    </div>
</template>

<script>
import HELLOWORLD from '../components/HelloWorld.vue'
export default {
    components:{
        HELLOWORLD
    },
    data(){
        return{
            
        }
    },
    methods:{
        getData(sonData){
            console.log("data=>",sonData);
        },
    }
}
</script>

<style lang="less" scoped>

</style>

SonComponent:

<template>
    <div>
        <h1>HELLOWORLD</h1>
    </div>
</template>

<script>
export default {
    data(){
        return{
            content:"content"
        }
    },
    mounted(){
        this.$emit("sendData",this.content);
    }
}
</script>

<style lang="less" scoped>

</style>

效果图:
在这里插入图片描述


实际上,为了数据能在父子组件间传值;还可以通过调用父组件的函数或调用子组件的函数的方式实现传值。

Vue中子组件调用父组件的函数

https://blog.youkuaiyun.com/qq_44849271/article/details/116559768

Vue父组件调用子组件的函数

https://blog.youkuaiyun.com/qq_44849271/article/details/116430693


Vuex是Vue框架中不可或缺的一部分;

Vuex在需要多组件通信的时候显得格外重要;比如数据在父组件形成,但数据需要在子组件的子组件中使用时,就可以使用Vuex管理;或者说需要兄弟组件传值时,可以使用Vuex。

在Vue的store.js中有五个属性:
分别是state,mutations,actions,getters,modules

结构为:

let a={
  state: {
  	name:"moduleA"
  },
  //mutations专门用于改变state属性中的数据
  mutations: {
  	setFun(state,item){
		state.name=item;
	}
  }
}

export default new Vuex.Store({
  //state专门存放数据
  state: {
  	num:100,
  	useAcomponent:{
		name:"A",
	},
	useBcomponent:"content",
  },
  //mutations专门用于改变state属性中的数据
  mutations: {
  	setStateFun(state,item){
		state.useBcomponent="Bcomponent";
	}
  },
  actions: {
  	httpGetData(store,item){
		setTimeout(()=>{
			console.log(item);
			store.commit("setStateFun",item);
		},3000)
	}
  },
  getters:{
  //调用getters中的函数时没有入参
	getterFun1(state){
		return state.num++
	}
  //调用getters中的函数时有入参
  	gettterFun2(state){
		return function(val){
			return state.num+=val;
		}
	}
  },
  modules: {
  	ModuleA:a
  }
});
}

state中的数据可以在不同组件中访问获取。

获取state的数据:

this.$store.state.state对象中的数据;
例如
let val=this.$store.state.num;

更改state数据,就是调用Vuex的mutations对象中的函数:

this.$store.commit("函数名","数据");
例如
this.$store.commit("setStateFun","testSetItem");

actions对象,用于在Vuex中发请求

this.$store.dispatch("函数名","数据");
例如
this.$store.dispatch("httpGetData","testItem");

getters对象,类似Vue的计算属性

this.$store.getters.函数名;
例如
//没入参时
this.$store.getters.getterFun1;
//有入参时
this.$store.getters.getterFun2(123);

modules对象,类似将需要使用的store模块化分开,每个modules对象对应一个模块

//获取modules对象中的state数据
this.$store.state.modules对象名.state值;
例如
this.$store.state.ModuleA.name
//使用modules对象中的mutations的函数
this.$store.commit("函数名","入参数据");
例如
this.$store.commit("setFun","itemabc");
//这里需要注意,如果modules模块中与外部(不是modules对象模块)的mutations对象中有相同名字的函数时,则相同名字的函调用时都会执行

有错误的地方欢迎大家要指出来~

欢迎大家补充

当我们需要在 Vue 应用程序中进行组件之间的通信时,我们可以使用 Vuex 来简化这个过程。Vuex 是一个专门为 Vue.js 应用程序开发的状态管理模式。它集中管理应用程序的所有组件的状态,并允许我们以一种可预测的方式进行修改和操作。 举个例子,假设我们有三个组件: - 组件(Parent) - 子组件1(Child1) - 子组件2(Child2) 组件和子组件1之间需要递数据,子组件2需要访问组件的数据。我们可以使用 Vuex 来实现这种组件之间的通信。 首先,我们需要创建一个 Vuex store,用于管理应用程序的状态: ```javascript import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const store = new Vuex.Store({ state: { message: '' }, mutations: { setMessage(state, payload) { state.message = payload } }, actions: { setMessage({ commit }, payload) { commit('setMessage', payload) } }, getters: { getMessage(state) { return state.message } } }) export default store ``` 这个 store 包含一个状态(message),一个 mutation(setMessage),一个 action(setMessage),以及一个 getter(getMessage)。 mutation 用于修改状态,而 action 用于触发 mutation。在这种情况下,我们只需要一个 mutation 和一个 action,因为我们只需要在组件和子组件1之间递数据。 现在,我们可以在组件中使用 action 来设置 message 状态,然后在子组件1中使用 getter 来获取 message 状态: ```javascript <template> <div> <child1 /> </div> </template> <script> import child1 from './Child1.vue' import { mapActions } from 'vuex' export default { components: { child1 }, methods: { ...mapActions(['setMessage']) }, mounted() { this.setMessage('Hello World!') } } </script> ``` 在这个例子中,我们使用了 mapActions 来将 setMessage action 映射到组件的 methods 中。然后,在组件的 mounted 钩子中,我们调用 setMessage action 并递一个字符串参数。 现在,我们可以在子组件1中使用 mapGetters 将 getMessage getter 映射到组件的 computed 中,然后在模板中使用它来获取 message 状态: ```javascript <template> <div> <p>{{ message }}</p> </div> </template> <script> import { mapGetters } from 'vuex' export default { computed: { ...mapGetters(['getMessage']), message() { return this.getMessage } } } </script> ``` 在这个例子中,我们使用了 mapGetters 将 getMessage getter 映射到组件的 computed 中。然后,在 computed 中我们定义了一个 message 计算属性来返回 getMessage getter。 最后,如果我们想让子组件2访问组件的数据,我们可以使用 $store.state.message 来直接访问 message 状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值