首页 > 其他 > 详细

vue项目中使用vuex

时间:2019-03-21 15:20:07      阅读:151      评论:0      收藏:0      [点我收藏+]

1、运行

cnpm i vuex -S

2、导入包

import Vuex from ‘vuex‘

3、注册vuex到vue中

Vue.use(vuex)

4、

var  store  = new Vuex.Store({
   state:{
     count: 0         
    },
    munctions: {
       setCount:(state , count)=>{
         state.count  = count
       }
     },
    getters:{
       // 注意:这里的  getters , 只负责 对外提供数据,不负责 修改数据,如果想要修改则去munctions
       optCount:(state) =>{
          return ‘当前最新的count值是:‘+ state.count   
       }    
        // 经过咋们的回顾对比,发现 getter 中的方法,和组件中的过滤器比较类似因为过滤器和getters 都没有修改原来数据 都是把原来的数据做了一层包装,提供给 调用者
        //其次 getters 也和 computed 比较像,只要state 中的数据发什么了变化 如果getters正好也引用了这个数据,那么就会立即触发 getters 的重新求值 ;
      } 
})      

import App from ‘./App.vue‘

const vm new Vue({
  el: ‘#app‘,
  render: c=>c(App),
  store //5、将 vuex 创建的 store 挂载到你vm 实例上,只要挂载到了vm 上 任何组件才都能使用store 来读取数据
})

总结:

1、state中的数据,不能直接修改,如果想要修改,必须通过 munctions

2、如果组件想要直接从  state 上获取数据:需要 this.$store.state.****

3、如果组件,想要修改数据,必须使用 munctions 提供的方法,需要通过 this.$store.commit(‘方法名称,唯一的一个参数‘)

4、如果 store 中的state 上的数据,在对外提供的时候,需要做一层包装,那么,推荐使用 getters,如果需要使用 getters ,则用 this.$store.getters.***

vue项目中使用vuex

原文:https://www.cnblogs.com/chen-cheng/p/10571795.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!