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>
index.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>
App.vue

//入口文件代码

 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>

 

posted @ 2019-05-04 15:44  xx_sprog  阅读(242)  评论(0)    收藏  举报