vuex

  • vue 插件 npm install vuex --save
  • 将多个组件的共享状态进行 集中式管理 - 极易破坏单向数据流
  • 多个视图依赖于同一状态 ----- 就 props 而言:嵌套组件传参繁琐,兄弟组件传参无能为力
  • 来自不同视图的行为需要变更同一状态

将组件的共享状态抽取出来: 组件共享的数据、后台请求数据

  • 核心对象 store

向外暴露 store 对象

状态自管理应用 分为

state -------- 驱动应用的 数据源

view -------- 以声明方式将 state 映射到视图 - template

actions -------- 响应有用户在 view 上的用户输入导致的状态变化 - methods: {}

action 中的 commit() 来触发 mutation 的调用,间接更新 state

一个 action 中可能有多个 commit("mutation的名字", 传参给mutation)

开发工具 会监视 mutations

---------------------------------------------------------------------------------------

src/store.js -------- vuex 最核心的管理模块

import Vue from "vue";

import Vuex from "vuex";

Vue.use(Vuex);

const state = {        // 包含所有状态数据的对象,相当于 data

count: 1        // 指定初始状态数据

};

const actions = {        // 包含 n 个用于间接更改共享状态数据方法的对象 - 分析对状态数据的几个间接操作

increment ({commit}) {commit("INCREMENT")}

decrement ({commit}) {commit("DECREMENT")}

incrementIfOdd ({commit, state}) {if(state.count%2===1)commit("INCREMENT")}

// 不像 react-thunk 才能实现 redux 的异步,vuex 本身就可以异步

incrementAsync ({commit}) {setTimeout(()=>commit("INCREMENT"), 1000)}    

};

const mutations = {        // 包含 n 个用于直接更改共享状态数据方法的对象 - 分析对状态数据的几个直接操作

INCREMENT (state) {state.count++}

DECREMENT (state) {state.count--}

};

const getters = {        // 包含了 计算属性 的定义

evenOrOdd(state){return state.count % 2 === 0 ? '偶数' : '奇数'}

};

export default new Vuex.Store({

state,

actions,

mutations,

getters

});

---------------------------------------------------------------------------------------

src/main.js

  • import Vue from 'vue'
    import App from './App.vue'
    import store from './store/index' /* eslint-disable no-new */
    new Vue({
    el: '#app',
    components: {
    App
    },
    template: '<App/>',
    store
    })


src/App.vue -------- 组件中使用 vuex 管理的状态数据 - ViexModel 即 组件对象的 this 会多一个 $store 对象

...

methods: {

increment () {this.$store.dispatch("increment")}

decrement () {this.$store.dispatch("decrement")}

incrementIfOdd () {this.$store.dispatch("incrementIfOdd")}

incrementAsync () {this.$store.dispatch("incrementAsync")}

}

...

------------------------------------ 简化写法 ------------------------------------

import {mapState, mapGetters, mapActions} from "vuex"

...

computed: {

...mapState(["count"]),        // 函数返回有一个对象,拆包解构以后再放入另一个对象

....mapGetters(["evenOrOdd"])

}        // 相当于:

methods: {...mapActions(["increment", "decrement", "incrementIfOdd", "incrementAsync"])}    // 用的少?因为只适合只有 this.$store 的函数

...


Vuex.Store({ modules: {...} }) --------- 大型项目,按 功能模块 合理拆分 store

Vuex 允许我们将 store 分割成模块(module)。

每个模块拥有自己的 state、mutation、action、getter、

甚至是嵌套子模块——从上至下进行同样方式的分割

  • 对于模块内部的 mutation 和 getter,接收的第一个参数是模块的局部状态对象

  • 同样,对于模块内部的 action,局部状态通过 context.state 暴露出来,根节点状态则为 context.rootState

  • 对于模块内部的 getter,根节点状态会作为第三个参数暴露出来

5

5

vue_vuex的更多相关文章

随机推荐

  1. Entity Framework入门教程(9)---离线场景附加实体图集到上下文

    附加离线实体图集到上下文 这节主要内容是通过不同的方法将离线实体附加到上下文中. 在离线场景中,保存一个实体要略微困难一些.当我们保存一个离线的实体图集或一个单独的离线实体时,我们需要做两件事.首先, ...

  2. 手写代码 - java.util.Arrays 相关

    1-拷贝一个范围内的数组 Arrays.copyOfRange( array, startIndex, endIndex); include startIndex... exclude endInde ...

  3. 【原创】Linux基础之上传下载

    1 rz sz 安装 yum install -y lrzsz 上传 rz ,对话框操作 下载 sz $filename 注意:rz不能上传大于4g的文件,此时可以改为scp或sftp上传,其中sft ...

  4. storage和memory

    memory:使用的是值传递,默认使用的是memory,传递的是值 storage:引用传递,传过来的是指针,后面一定要加上internal,private pragma solidity ^; co ...

  5. Okhttp同步请求源码分析

    进阶android,OKhttp源码分析——同步请求的源码分析 OKhttp是我们经常用到的框架,作为开发者们,我们不单单要学会灵活使用,还要知道他的源码是如何设计的. 今天我们来分析一下OKhttp ...

  6. springMVC下载中文文件名乱码【转】

    //遇到的现象是,下载含有中文文件名的文件时,能获取到文件,但是使用IE正常,使用firefox,chrome文件名却乱码.//既然如此,就区分一下浏览器再返回好了,处理方式如下 //RESTfull ...

  7. VC调用静态库、动态库

    静态库 // 相对路径 或者 绝对路径 #include "yourlib.h" //相对路径 或者 绝对路径 #pragma comment(lib, "yourlib ...

  8. 关于在windows上远行的虚拟机为ubuntu16.04中不能复制和粘贴的问题解决方案

    Linux安装 VMware tools 工具解决复制和粘贴的方法 VMware虚拟机中如何安装VMWare-Tools详解好处:可以支持图形界面,可以支持共享文件功能等 1 工具/原料 1)安装过虚 ...

  9. 金蝶K3 WISE BOM多级展开_物料齐套表

    /****** Object: StoredProcedure [dbo].[pro_bobang_ICItemQiTao] Script Date: 07/29/2015 16:12:10 **** ...

  10. IDEA手动创建JFinal项目

    http://www.jfinal.com/share/674 https://www.oschina.net/question/265150_110300