一、什么是vuex
vuex是在vue项目中实现数据共享的框架。用于当多个组件进行复杂的数据传值很困难的时候。这时将某个数据放在公共的存储空间去存储, 当某一个组件改变这个公共的数组,所有其他引用这个数据的组件能够动态感知到。
官网: https://vuex.vuejs.org/zh/
data:image/s3,"s3://crabby-images/77227/772274072cddb082436d0afbc23c9a307d82284e" alt=""
二、怎么用
1.安装
npm install vuex --save
2.引入
import Vuex from 'vuex'
3.新建一个store目录,用于存放vuex数据。
新建 store/index.js
data:image/s3,"s3://crabby-images/e58f5/e58f553480494d1564cfe418b2d2b42639e46bc8" alt=""
在入口文件中引入store
data:image/s3,"s3://crabby-images/7bde9/7bde938e4b2c89ecbf17f1751b903677f4c55dcd" alt=""
使用的时候
data:image/s3,"s3://crabby-images/8c47c/8c47c6bfd39d05b7c72805ce33b1fad41b80da67" alt=""
因为在main.js(全局中注册)中使用了store,因此store里的数据会被派发到各个组件中。
三、怎么修改
1.dispatch一个actions。一个参数是派发actions的名字,第二个是要传的数据。
data:image/s3,"s3://crabby-images/3e811/3e81112c770e12bbd9f813f7f135cb2ee3e7090f" alt=""
2.在store中创建一个跟派发actions名字(changeCity)相同的action。一个参数是上下文ctx,第二是传过来的数据city
data:image/s3,"s3://crabby-images/33363/33363329d1bb13e3084b4c8e4c64aeb307287515" alt=""
3.actions需要commit mutations
data:image/s3,"s3://crabby-images/a3c99/a3c99635eff5dcb399cc0587e1b93a83168baed4" alt=""
四、如果没有复杂业务逻辑,可以通过组件直接调用mutations
data:image/s3,"s3://crabby-images/a9157/a915766603536ccd43121528f5fa096154b08c06" alt=""
五、mapState
mapState是将vuex中state数据映射到组件中,在computed计算属性中,将state中的city数据,自定义命名为currentCity
data:image/s3,"s3://crabby-images/54ffd/54ffd55f77bffc6f2584a56d88cd46fa50e125c9" alt=""
使用的时候
data:image/s3,"s3://crabby-images/98c3f/98c3f7685ab4896521bca34b6292281085c73cc5" alt=""
六、mapMutations
使用:不用写成绿框中的内容了,直接写成this.changeCity(city)即可
data:image/s3,"s3://crabby-images/b150d/b150d2f21c5fef6b956dff854195d32da14a574e" alt=""
网友评论