码迷,mamicode.com
首页 > 其他好文 > 详细

Vuex

时间:2019-12-21 10:17:14      阅读:91      评论:0      收藏:0      [点我收藏+]

标签:count   imp   vue   out   共享数据   页面   from   接受   安装   

组件之间小范围共享数据的方式
1.父向子传值:v-bind
2.子向父传值:v-on 事件绑定
3.兄弟组件之间的数据共享 EventBus
$on 接受数据的那个组件
$emit发送数据的那个组件

使用vuex的好处
1.能够集中管理共享的数据,易于开发和后期维护
2.能够高效的实现组件之间的数据共享,提高开发效率
3.存储在vuex中的数据都是响应式的,能够实时保持数据与页面的同步

什么样的数据适合存储在vuex中
只有组件之间共享的数据才有必须要存储到vuex中,对于组件中的私有数据,依旧存储在组件中的data中

vuex的使用
安装vuex
npm install vuex --save

导入vuex包
import Vuex from "vuex"

Vue.use(Vuex)

创建store对象

const store = new Vuex.Store({
    //state中存放的就是共享的数据
        state:{
           count:0
        }

})
在导出的时候new Vuex.Store中的Store,这里首字母一定要大写,就相当于我们在使用构造函数(类)的时候首字母要大写
将store对象挂载到Vue实例中
new Vue({
    el:"#app",        render:h=>h(app),
        router,
      store   //所有的组件就可以从store中获取全局的数据了
})

Vuex的核心概念

state
提供唯一的公共数据源,所有共享的数据都要统一放到store中的state中进行存储
组件访问state中数据的第一种方式 this.$store.state.全局数据名称 在template中this可以省略
组件访问state中数据的第二种方式

1、从vuex中按需导入mapState函数
import {mapState} from "vuex"
2、将全局数据映射为当前组件的计算属性
computed:fucntion(){
   ...mapState([‘count‘])
}

通过刚才导入的mapState函数
将当前组件需要的全局数据,映射为当前组件的computed计算属性

Vuex

标签:count   imp   vue   out   共享数据   页面   from   接受   安装   

原文地址:https://blog.51cto.com/13550695/2460328

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!