Vuex的使用
// html代码
1 <!DOCTYPE html> 2 <html lang="en"> 3 4 <head> 5 <meta charset="UTF-8"> 6 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 7 <meta http-equiv="X-UA-Compatible" content="ie=edge"> 8 <title>Document</title> 9 </head> 10 11 <body> 12 <!-- 这是容器 --> 13 <div id="app"></div> 14 </body> 15 16 </html>
//主模板文件导入其它模板文件的代码
1 <template> 2 <div> 3 <h1>这是 App 组件</h1> 4 5 <hr> 6 7 <counter></counter> 8 <hr> 9 <amount></amount> 10 11 </div> 12 </template> 13 14 <script> 15 import counter from "./components/counter.vue"; 16 import amount from "./components/amount.vue"; 17 18 export default { 19 data() { 20 return {}; 21 }, 22 components: { 23 counter, 24 amount 25 } 26 }; 27 </script> 28 29 <style lang="scss" scoped> 30 31 </style>
//入口文件代码
1 // 入口文件 2 import Vue from 'vue' 3 // 配置vuex的步骤 4 // 1. 运行 cnpm i vuex -S 5 // 2. 导入包 6 import Vuex from 'vuex' 7 // 3. 注册vuex到vue中 8 Vue.use(Vuex) 9 // 4. new Vuex.Store() 实例,得到一个 数据仓储对象 10 var store = new Vuex.Store({ 11 state: { 12 // 大家可以把 state 想象成 组件中的 data ,专门用来存储数据的 13 // 如果在 组件中,想要访问,store 中的数据,只能通过 this.$store.state.*** 来访问 14 count: 0 15 }, 16 mutations: { 17 // 注意: 如果要操作 store 中的 state 值,只能通过 调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据,因为 万一导致了数据的紊乱,不能快速定位到错误的原因,因为,每个组件都可能有操作数据的方法; 18 increment(state) {//第一个参数规定死了 19 state.count++ 20 }, 21 // 注意: 如果组件想要调用 mutations 中的方法,只能使用 this.$store.commit('方法名') 22 // 这种 调用 mutations 方法的格式,和 this.$emit('父组件中方法名') 类似 23 subtract(state, obj) { 24 // 注意: mutations 的 函数参数列表中,最多支持两个参数,其中,参数1: 是 state 状态; 参数2: 通过 commit 提交过来的参数; 25 console.log(obj) 26 state.count -= (obj.c + obj.d) 27 } 28 }, 29 getters: { 30 // 注意:这里的 getters, 只负责 对外提供数据,不负责 修改数据,如果想要修改 state 中的数据,请 去找 mutations 31 optCount: function (state) { 32 return '当前最新的count值是:' + state.count 33 } 34 // 经过咱们回顾对比,发现 getters 中的方法, 和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者; 35 // 其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值; 36 } 37 }) 38 39 // 总结: 40 // 1. state中的数据,不能直接修改,如果想要修改,必须通过 mutations 41 // 2. 如果组件想要直接 从 state 上获取数据: 需要 this.$store.state.*** 42 // 3. 如果 组件,想要修改数据,必须使用 mutations 提供的方法,需要通过 this.$store.commit('方法的名称', 唯一的一个参数) 43 // 4. 如果 store 中 state 上的数据, 在对外提供的时候,需要做一层包装,那么 ,推荐使用 getters, 如果需要使用 getters ,则用 this.$store.getters.*** 44 45 46 import App from './App.vue' 47 48 const vm = new Vue({ 49 el: '#app', 50 render: c => c(App), 51 store // 5. 将 vuex 创建的 store 挂载到 VM 实例上, 只要挂载到了 vm 上,任何组件都能使用 store 来存取数据 52 })
//操作的vueX的模板文件代码
1 <template> 2 <div> 3 <input type="button" value="减少" @click="remove"> 4 <input type="button" value="增加" @click="add"> 5 <br> 6 <input type="text" v-model="$store.state.count"> 7 </div> 8 </template> 9 10 <script> 11 export default { 12 data() { 13 return { 14 // count: 0 15 }; 16 }, 17 methods: { 18 add() { 19 // 千万不要这么用,不符合 vuex 的设计理念 20 // this.$store.state.count++; 21 this.$store.commit("increment"); 22 }, 23 remove() { 24 this.$store.commit("subtract", { c: 3, d: 1 }); 25 } 26 }, 27 computed:{ 28 fullname: { 29 get(){}, 30 set(){} 31 } 32 } 33 }; 34 </script> 35 36 <style lang="scss" scoped> 37 38 </style>
//操作vueX的模板文件代码
1 <template> 2 <div> 3 <!-- <h3>{{ $store.state.count }}</h3> --> 4 <h3>{{ $store.getters.optCount }}</h3> 5 6 </div> 7 </template> 8 9 <script> 10 </script> 11 12 <style lang="scss" scoped> 13 14 </style>

浙公网安备 33010602011771号