Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
前言
vuex的执行流程
组件通过dispatch调用action,action通过commit来触发mutation,mutation来负责修改state,state修改后去重新渲染受影响的dom。
安装和引入
1、安装
npm install vuex -S
2、引入
新建:store/index.js。
import vue from 'vue'; import Vuex from 'vuex'; vue.use(Vuex); export default new Vuex.Store({ strict:true,//严格模式,防止直接修改state(性能很差,发布时改为false) state:{ a:1, b:2 }, mutations:{ addA(state,val){ state.a+=val; }, addB(state,val){ state.b+=val; } }, actions:{ addA({commit},val){ //调用mutations中的addA() commit('addA', val); }, addB({commit},val){ //调用mutations中的addB() commit('addB', val); } }, //相当于computed getters:{ getA(state){ return state.a; }, getB(state){ return state.b; }, count(state){ return state.a + state.b; } }, modules:{ } });
3、挂载
import store from './store'; new Vue({ el: '#app', store, components: { App }, template: '<App/>' })
使用
映射关系
mapState > computed
mapGetters > computed
mapMutations > methods
mapActions > methods
State和mapState
state是vuex的核心,是统一存放数据的地方。
从store中获取值。(不推荐)
<template> <div> a:{{$store.state.a}} <br> b:{{$store.state.b}} </div> </template>
官方推荐通过computed来获取,但是如果需要获取多个值就会很麻烦。
mapState
<template> <div> a:{{a}} <br> b:{{b}} </div> </template> <script> import {mapState} from 'vuex'; export default { name: "MapState", computed:{ //将store.state中的属性映射到computed ...mapState(['a','b']) } } </script>
getters和mapGetters
获取getters中的值。
<div> a:{{$store.getters.getA}} <br> b:{{$store.getters.getB}} <br> a+b={{$store.getters.count}} </div>
使用mapGetters映射。
<template> <div> a={{getA}} <br> b={{getB}} <br> a+b={{count}} </div> </template> <script> import {mapGetters} from 'vuex'; export default { name: "MapGetters", computed:{ //将store.getters映射到computed ...mapGetters(['getA','getB','count']) } } </script>
mutations和mapMutations
通过$store.commit来触发mutation。
不推荐直接调用mutation来修改。
<template> <div> a={{$store.state.a}} <br> b={{$store.state.b}} <br> a+b={{$store.getters.count}} <hr> <button @click="$store.commit('add',5)">a+5</button> </div> </template>
使用mapMutations映射。
<template> <div> a={{$store.state.a}} <br> b={{$store.state.b}} <br> a+b={{$store.getters.count}} <hr> <button @click="addA(5)">a+5</button> </div> </template> <script> import {mapMutations} from 'vuex'; export default { name: "MapMutations", methods:{ //将store.mutations映射到methods ...mapMutations(['addA']) } } </script>
actions和mapActions
官方推荐通过action去触发mutation,虽然比较麻烦。
action支持异步,mutation只能同步。
通过$store.dispatch来触发action。
<button @click="$store.dispatch('addA',5)">a+5</button>
使用mapActions映射。
<template> <div> a={{$store.state.a}} <br> b={{$store.state.b}} <br> a+b={{$store.getters.count}} <hr> <button @click="$store.dispatch('addA',5)">a+5</button> </div> </template> <script> import {mapActions} from 'vuex'; export default { name: "MapActions", methods:{ //将store.actions映射到methods ...mapMutations(['addA']) } } </script>
Modules
当系统比较庞大时,store会变得非常臃肿。
为了方便store的模块化管理,Vuex 允许我们将 store 分割成 modules。
每个模块拥有自己的 state、mutation、action、getter、甚至是嵌套子模块。
补充知识:向vuex存储数据和获取数据-和直接调用actions.js中的异步方法
向vuex的变量存储数据
1.在state.js中添加 userInfo: {},
2.actions.js中添加同步用户信息-将参数userInfo传递给USER_INFO
创建一个方法-不用异步方法
syncUserInfo({commit}, userInfo){ commit(USER_INFO, {userInfo}); },
3.创建一个中间变量mutation-types.js
export const USER_INFO = 'user_info';
4.在actions.js中引入变量-USER_INFO
import { USER_INFO } from './mutation-types'
5.在mutations.js中引入变量
import { USER_INFO } from './mutation-types'
将userInfo赋值给state
[USER_INFO](state, {userInfo}) { state.userInfo = userInfo; },
6.外界直接调用actions.js中的方法 syncUserInfo
import {mapActions} from 'vuex' methods: { // 存到vuex-是个方法。需要...延展符展开 ...mapActions(['syncUserInfo']), }
向vuex中获取数据
1.引入 import {mapState} from 'vuex';
2.计算属性
computed:{ ...mapState(['userInfo']) },
直接调用vuex-中 actions.js的异步方法--
this.$store.dispatch
created(){ // 调用vuex-actions中的方法-刚进入app,就需要验证登录的时效性 this.$store.dispatch('getUserInfo') },
actions.js
// 7. 异步获取用户信息 async getUserInfo({commit}){ const result = await getUserInfo(); // actions中调用getUserInfo方法---需要引入import console.log(result); if(result.success_code === 200){ commit(USER_INFO, {userInfo: result.message}); } },
actions中调用getUserInfo方法---需要引入
import { getUserInfo, } from '../api' ---------------------- api-index.js // 2.9 获取登录的用户信息 export const getUserInfo = () => ajax(BASE_URL + '/api/user_info');
以上这篇vuex存取值和映射函数使用说明就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】