vuex官网文档 https://vuex.vuejs.org/zh-cn/

注: Mutation事件使用commit触发, Actions事件使用dispatch触发

安装 npm install vuex --save

创建store文件/store.js

// store.js
import Vue from 'vue'
import Vuex from 'vuex' Vue.use(Vuex)
let state = {
// 管理所有数据
name: 'default name'
} let mutations = {
// 如需要修改state, 全部方法集中在这管理
change(state, name){
state.name = name
}
} let actions = {
// 组件所有的 异步,同步事件在这里处理
change({commit}){
var name = 'ajanuw'
commit('change', name);// 需要修改state.name交更mutations处理
}
} let getters = {
// 组件需要 state数据全部在这里请求
getName(state){
return state.name
}
} // 导出
export default new Vuex.Store({
actions,
getters,
mutations,
state
})

main.js 获取store

// main.js
import store from './store/store.js'
new Vue({
store
})

组件内部

// App.vue
<template>
<div id="app">
<p>{{ getName}}</p>
<button @click="change"> change name</button>
</div>
</template> <script>
import {mapGetters, mapActions} from 'vuex'
export default {
computed: mapGetters([
'getName'
]), methods: mapActions([
'change'
])
}
</script>

分离store.js

└─store
actions.js
getters.js
mutations.js
state.js
store.js
---
// store.js
import Vue from 'vue'
import Vuex from 'vuex' import state from './state'
import mutations from './mutations'
import actions from './actions'
import getters from './getters' Vue.use(Vuex) // 导出
export default new Vuex.Store({
actions,
getters,
mutations,
state
}) ---
// state.js
export default {
// 管理所有数据
name: 'default name'
}

补充一个 mapState

// App.js

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

  computed: mapState({
age: 'age', // 映射 state.age tody(){// 定义局部数据
return "好日子"
}, storeName(state){// this指向局部
return `${state.name} ${this.name}`
}
}), render(h){
return (
<p>{ this.age }</p>
<p>{ this.tody }</p>
<p>{ this.storeName }</p>
);
}

一些vuex操作, dispatch

// App.js
import {mapState, mapGetters, mapActions} from 'vuex' export default {
data(){
return {
name: 'ajanuw'
}
},
computed:{
...mapState({
defaultname: 'name',
num: 'num'
})
},
methods:{
hello(msg){
return `hello ${msg}`
},
...mapActions({// 映射store里面的action.prop
decrease: 'decrease'
})
},
render(){
var store = this.$store;
return (
<div id="app">
/*methods钩子的的函数*/
<p>{ this.hello('vue vuex jsx') }</p>
<br />
/*data钩子里的的state*/
<p>hello {this.name}</p>
<br />
/*映射store里面的state*/
<p>{this.defaultname}</p>
<br />
/*store.dispatch() 派发事件*/
<p>
<button onClick={ ()=>store.dispatch('addnum', 1) } >click延迟一秒+1 => {this.num}</button>
</p> <br /> /* 使用mapActions() 映射store的action*/
<p>
<button onClick={ ()=> this.decrease(2) } >click延迟一秒-2 => {this.num}</button>
</p> <br />
</div>
)
},
mounted(){
console.log( this);
}
}
// store.js
import Vue from 'vue';
import Vuex from 'vuex'; Vue.use(Vuex); let state = {
name: 'default name',
num: 0
} let mutations = {
addnum(state, n){
state.num += n;
}, decrease(state, n){
state.num -= n;
}
} let actions = {
addnum(ctx, n){
setTimeout( ()=> ctx.commit('addnum', n), 1000);
}, decrease(ctx, n){
setTimeout( ()=> ctx.commit('decrease', n), 1000);
}
} let getters = { } export default new Vuex.Store({
actions,
getters,
mutations,
state
});

module 分割store https://vuex.vuejs.org/zh-cn/modules.html

// App.js
import {mapState, mapGetters, mapActions} from 'vuex'; export default {
data(){
return {}
},
created(){
this.$store.registerModule('modelC', {
// 动态注册一个model
// store.unregisterModule(moduleName) 来动态卸载模块
namespaced: true,
state: {
msg: '动态modelC'
}
});
},
methods:{
...mapActions('modelA', {
show: 'show'
})
},
render(){
const store = this.$store;
return (
<div id="app">
<p>hello</p>
<p onClick={()=>store.dispatch('modelA/show')}>modelA => {store.state.modelA.msg}</p> <p onClick={ ()=>store.dispatch('modelB/show') }>modelB => {store.state.modelB.msg}</p>
</div>
)
},
mounted(){
this.show();
console.log( this.$store.state.modelC.msg );
this.$store.unregisterModule(modelC);
// modelC 已经被卸载,下面的代码将会报错
console.error( this.$store.state.modelC.msg );
}
}
// store.js
import Vue from 'vue';
import Vuex from 'vuex';
Vue.use(Vuex);
/*
默认情况下,模块内部的 action、mutation 和 getter 是注册在全局命名空间的
这样使得多个模块能够对同一 mutation 或 action 作出响应。 如果希望你的模块具有更高的封装度和复用性,
你可以通过添加 namespaced: true 的方式使其成为命名空间模块。
当模块被注册后,它的所有 getter、action 及 mutation 都会自动根据模块注册的路径调整命名
*/ const modelA = {
namespaced: true,
state: {
msg: 'this is modelA',
},
mutations: {},
actions: {
show(ctx){
console.log( ctx.state.msg );
}
},
getters: {}
} const modelB = {
namespaced: true,
state: {
msg: 'this is modelB',
},
mutations: {},
actions: {
show(ctx){
console.log( ctx.state.msg );
}
},
getters: {}
} const store = new Vuex.Store({
modules: {
modelA,
modelB
}
}); export default store;

萌新 学习 vuex的更多相关文章

  1. 萌新学习Python爬取B站弹幕+R语言分词demo说明

    代码地址如下:http://www.demodashi.com/demo/11578.html 一.写在前面 之前在简书首页看到了Python爬虫的介绍,于是就想着爬取B站弹幕并绘制词云,因此有了这样 ...

  2. php萌新|学习|排坑|のmysqli_error()方法的妙用

    从开始学习php当现在已经有一个月多.除了每天完成公司布置的日常汇报,也没有耐下性子写一写自己想写的东西.今天就当起个头,坚持一周有个两三片文章或者小总结,也不枉费自己的付出.(我自己都不信,你会信吗 ...

  3. 萌新学习SpringMVC

    前言 只有光头才能变强. 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 这篇SpringMVC被催了很久了,这阵子由于做 ...

  4. 萌新学习图的强连通(Tarjan算法)笔记

    --主要摘自北京大学暑期课<ACM/ICPC竞赛训练> 在有向图G中,如果任意两个不同顶点相互可达,则称该有向图是强连通的: 有向图G的极大强连通子图称为G的强连通分支: Tarjan算法 ...

  5. IIFE 萌新学习笔记

    立即执行函数表达式(IIFE) IIFE:Immediately-Invoked Function Expression(立即执行函数表达式) 一 常用写法: //经常使用的写法(function() ...

  6. 萌新笔记——C++里创建 Trie字典树(中文词典)(三)(联想)

    萌新做词典第三篇,做得不好,还请指正,谢谢大佬! 今天把词典的联想做好了,也是比较low的,还改了之前的查询.遍历等代码.  Orz 一样地先放上运行结果: test1 ID : char : 件 w ...

  7. 萌新笔记——C++里创建 Trie字典树(中文词典)(二)(插入、查找、导入、导出)

    萌新做词典第二篇,做得不好,还请指正,谢谢大佬! 做好了插入与遍历功能之后,我发现最基本的查找功能没有实现,同时还希望能够把内存的数据存入文件保存下来,并可以从文件中导入词典.此外,数据的路径是存在配 ...

  8. 萌新笔记——C++里创建 Trie字典树(中文词典)(一)(插入、遍历)

    萌新做词典第一篇,做得不好,还请指正,谢谢大佬! 写了一个词典,用到了Trie字典树. 写这个词典的目的,一个是为了压缩一些数据,另一个是为了尝试搜索提示,就像在谷歌搜索的时候,打出某个关键字,会提示 ...

  9. 萌新关于C#委托一点见解

    开博第一写C#委托(一个简单的委托) 1.关于委托,一直是学习c#的萌新们的噩梦,小生也是.最近在学委托感觉瞬间被虐成狗,但作为C#中极为重要的一个内容,学好了将会及大地减少我们的代码量,而且这也是够 ...

随机推荐

  1. 获取gcc和clang的内置宏定义

    下面是对Gcc的内置宏定义的解释: https://gcc.gnu.org/onlinedocs/cpp/Common-Predefined-Macros.html https://github.co ...

  2. Oracle创建Database Link

    一菜单方式: 打开plsql,点击[File]-[New]-[Database link],打开如下图所示窗口 填好各项信息后,点击[Apply]即可完成Database Link的创建. 二SQL方 ...

  3. sshd服务

    SSHD服务 介绍:SSH 协议:安全外壳协议.为 Secure Shell 的缩写.SSH 为建立在应用层和传输层基础上的安全协议. 作用 sshd服务使用SSH协议可以用来进行远程控制, 或在计算 ...

  4. Linux下修改环境变量,不小心改错,找不到命令解决办法

    PATH改错了找不到命令 解决方法: 重新定义PATH export PATH=/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/us ...

  5. Win10系统的SurfacePro4无法修改启动顺序怎么办

    必须要把底部的开关关闭,否则启动顺序无法修改      

  6. linux apache2部署php

    apache2 doc http://blog.csdn.net/actor1999/article/details/44802519 #apache sudo apt-get install apa ...

  7. 一些Android手机的平台信息

    1.OPPO A83 (2018-04-16) A83:/ $ cat /system/build.prop | grep "product"# ro.product.cpu.ab ...

  8. manjaro折腾手记

    以前装过Arch,有点折腾,写了个hello world就卸载了.没用过AUR,甚至也没去了解. 听说manjaro继承Arch,几乎开箱即用,对硬件支持非常好,源里面的软件更新非常快.但是没有装中文 ...

  9. js 动态生成html 触发事件传参字符转义

    通常,在使用 JS 动态生成 html 的过程中,会嵌入相应的样式.事件等属性元素,而这时经常会出现所谓的 “单.双引号不够用” 的情况,别急,这时可以利用 html 语言中的转义字符来解决.下面就来 ...

  10. Mysql中NUMERIC和DECIMAL类型区别比较

    decimal(numeric ) 同义,用于精确存储数值 . decimal 数据类型最多可存储 38 个数字,所有数字都能够放到小数点的右边.decimal 数据类型存储了一个准确(精确)的数字表 ...