vuex能传参吗_我对vuex的理解(二) 之 mapGetters取值和mapMutations的传参

前言:最近在做一个vue的项目,碰到一点关于mapMutations传参的问题,解决完问题了所以写一下对它理解。

棒棒团公益免费性质,欢迎加阳叔WX:erdaori 拉你入群

1、官网中的提交载荷(传参)具体到一般demo中大概是这样的

const store new Vuex.Store({

state: {

count: 0

},

mutations: {

increment(state,n){

state.count += n

}

}

})

new Vue({

el:"#app",

store,

computed: {

count() {

return store.state.count

}

},

methods: {

add() {

//传参

store.commit('increment',10)

}

}

})

2、具体到项目中,用mapMutations辅助函数的传参新建一个store.js文件

//store.js

import Vue from 'vue'

import Vuex from 'vuex'

Vue.use(Vuex)

//定义state,并将listName设置为一个空对象

const state = {

listName: {}

}

//定义mutations,可以传参,用于设置state里的listName

const mutations = {

set_listname: (state,value) => {

state.listName=value

}

}

//定义getters,用于获取出state里的对象

const getters = {

get_listname: state => {

return state.listName

}

}

export default new Vuex.Store({

getters,

state,

mutations

})在vue实例中注册store

//main.js

import Vue from 'vue'

import App from './App'

import store from './store'

/* eslint-disable no-new */

new Vue({

el: '#app',

router,

store,

template: '',

components: { App }

})

在App.vue组件中使用mapMutations传参,修改state数据(状态)

要点: 要写在methods下面,因为mapActions/mapMutations只是把action/mutation函数绑定到你的methods里了;你调methods里的方法的时候照常传参就可以了。

//App.vue

import {mapMutations} from 'vuex'

export default {

//定义一个listName,作为下面的mapMutations的传参参数,修改state的listName

data() {

listName: {

name:'Ewall',

age:'21'

}

},

created (){

//调用set_listname方法,将listName对象作为参数传入

this.set_listname(listName)

},

methods: {

...mapMutations(['set_listname'])

},

}

再定义一个子组件,获取state对象里面的数据

//app-child.vue

import {mapGetters} from 'vuex'

export default {

computed: {

//获取state里面的listName对象

...mapGetters(['get_listname'])

},

created() {

//打印下获得数据结果

console.log(this.get_listname)

}

}

在 Vue3 中使用 `vue-router` 实现路由跳转并传递参数,可以通过配置动态路由、调用 `router.push` 或 `<router-link>` 进行跳转,并通过 `useRoute` 获取目标路由的参数。以下是具体实现方法: ### 配置动态路由 首先,在定义路由规则时,可以设置动态路由参数,例如 `/user/:id`。这种方式允许将路径中的某一部分作为参数传递到目标组件中。 ```javascript import { createRouter, createWebHistory } from 'vue-router'; const routes = [ { path: '/user/:id', // 动态参数 :id component: () => import('@/views/UserDetail.vue') } ]; const router = createRouter({ history: createWebHistory(), routes }); export default router; ``` ### 路由跳转并传递参数 在需要触发路由跳转的场景下,可以通过 `useRouter` 提供的 `push` 方法进行跳转,并传递参数。以下是一个示例: ```javascript import { useRouter } from 'vue-router'; export default { setup() { const router = useRouter(); const navigateToUser = (userId) => { router.push({ name: 'user', params: { id: userId } // 传递参数 }); }; return { navigateToUser }; } }; ``` ### 在目标组件中获取参数 为了获取目标路由的参数,可以使用 `useRoute` API 来访问当前路由的信息,并从中提取所需的参数。 ```javascript import { useRoute } from 'vue-router'; export default { setup() { const route = useRoute(); const userId = route.params.id; // 获取动态参数 return { userId }; } }; ``` ### 注意事项 - 确保动态路由名称与跳转时指定的 `name` 属性一致。 - 如果使用 `<router-link>` 组件跳转,则可以直接在模板中传递参数: ```html <router-link :to="{ name: 'user', params: { id: 123 }}">用户详情</router-link> ``` - 在目标组件中,`route.params` 包含了所有动态路由参数,因此可以灵活地访问多个参数。 通过上述步骤,可以在 Vue3 应用中完成路由跳转参数传递的功能[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值