vuex是什么东西?
vuex是什么鬼?
文档上面对vuex的解释是 "一个专为 Vue.js 应用程序开发的状态管理模式",恩,看完这句是否对vuex有了一个大概的认识?
答案是:"认识你个蛇头"。
好吧,在我的认识里,vuex其实就是将组件中的数据集中起来管理的东西,vue是一个根据数据渲染视图的框架,当组件中的数据变化了,视图相应的产生变化,那这里的数据变化,也可以称作是状态变化,所以官方给的解释是一个 "状态管理模式"。
了解一下vuex的安装和使用
- 和vue-router差不多,直接用包管理工具安装即可 -- npm install vuex / yarn add vuex
- 在入口文件中引入 vuex ,在注册到Vue实例中
import Vuex from 'Vuex'
Vue.use(Vuex)
使用vuex
- 既然vuex是一个把数据集中起来管理的东西,那么我们将数据集中在哪里?
- 怎么访问这些集中起来的数据?
- 如果这些数据需要修改计算,那么用何种方式计算这些数据?
开始使用vuex,vuex用数据仓库(store)来管理被集中起来的数据,我们在使用vuex的时候,首先new一个Vuex.store的实例,为了管理方便,一般我们新建一个目录专门用来存放store仓库,在vuex中需要用到vue,所以首相引入vue,vuex,再通过new方法构建出一个数据仓库的实例。
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex);
export default new Vuex.store({参数对象})
在根组件中引入这个Vuex.store实例,将其注册到Vue实例中
import Vue from 'vue'
import App from './App'
import router from './router'
import Vuex from 'Vuex'
import store from './store' //引入Vuex.store实例
Vue.config.productionTip = false
Vue.use(Vuex);
new Vue({
el: '#app',
router,
store, //把Vuex.store的实例给到Vue实例中的store属性
template: '<App/>',
components: { App }
});
在创建实例的时候传入的参数对象中,有一个state属性,在这个属性中用来存放全局的应用数据,组件中的data存放的是局部数据。
在我们把Vuex.store实例注入到Vue实例中的时候,Vue实例对象下就会多出来一个属性:$store,我们在组件内部可以通过this.$store来访问这个Vuex.store实例。通过this.$store.state来访问被存起来的全局数据。
为了满足对数据的各种操作,在Vuex.store实例对象参数中除了state之外还有很多属性:
- getters
- 在这个属性中存放着state原始数据的派生数据,类似于组件中的计算属性,当我们在state中取出的原始数据需要早计算之后再使用的时候,可以用getters来对数据进行处理。
- getters属性的值是一个对象,对象下存放着计算数据的方法,这些方法接收两个参数
- store的state (原始数据)
- store的getters (计算后数据)
- Mutation
- 从外部更改store中数据的唯一方法就是在外部提交一个mutation,当组件在使用数据的过程中,通过用户的操作或其他途径需要对store中的数据进行修改时,不能直接修改,唯一的办法是向store提交一个mutation,store的Mutation属性下检测提交的mutation,将修改数据的工作交由Mutation处理
- this.$store.commit('事件名',事件处理函数的参数)
- 在Vuex.store的实例参数中的Mutation中声明这个事件处理函数,对数据进行处理
- Action
在Vuex中除了Mutation还有一个属性可以用来修改数据,和Mutation类似,但又不同,不同之处在于:
- Mutation处理之后不会返回任何结果
- Action 处理提交的也是Mutation,不是直接更改状态(数据),Action可以包含任意异步操作
- Action通过 this.$store.dispatch('事件名',参数)
- 如果我们希望store修改完数据以后会返回数据给组件,那么使用actions,否则使用mutations
vuex是什么东西?的更多相关文章
- 04 DRF内容回顾、用户登录 (含跨域) (vuex vue-cookie)、用户认证 (Auth认证)(拦截器)
1.内容回顾 1.视图中常见的继承 2.频率访问控制源码 3.序列化,反序列化 2.初始化代码 1.后端代码:AuthView (1)目录结构 (2)urls (3)view (4)注释掉cors ( ...
- vue项目缓存最佳实践
需求 在开发vue的项目中有遇到了这样一个需求:一个视频列表页面,展示视频名称和是否收藏,点击进去某一项观看,可以收藏或者取消收藏,返回的时候需要记住列表页面的页码等状态,同时这条视频的收藏状态也需要 ...
- js 的七大原则--单一原则、开闭原则、替换原则(一)
一.前言: js 的七大设计原则: 1.单一原则 2.开闭原则 3.里氏替换原则 4.依赖倒转原则 5.接口隔离原则 6.合成复用原则 7.迪米尔法则 二.单一原则 1.定义:单一原则就是一个对象或者 ...
- 摘抄大神对VUE 中slot-scope的深度理解
Vue的slot-scope的场景的个人理解 这篇文章不是单纯把文档的话和api拿来翻译和演示,而是谈谈我对于slot-scope的使用场景的个人理解,如果理解错误,欢迎讨论! Vue的插槽slot, ...
- 低耦合高内聚 - 不要把所有东西都放在 vuex中
我就举一个例子.比如,我想看电视,是否需要遥控器??请认真思考这个问题. 看似电视与“我”已经解耦了.然而,我需要通过遥控器去看电视,我的目的是看电视,但是我却需要依赖遥控器这个中间件.这就变相地将“ ...
- 关于Vue vuex vux 文档
01. vue 链接 http://vuejs.org.cn/guide/ 02. vuex ----->>状态管理模块儿<<------- https://vuex.vue ...
- Vue2.X的状态管理vuex记录
记住上述的顺序情况:想要改变state,只能通过Mutation,虽然action可以直接改变state,这样会使每个状态可以方便的跟踪和记录(用Devtools跟踪) vue Method -- ...
- 我的音乐盒子(nodejs7 + koa2 + vue + vuex + vue-router)
你们知道的,nodejs对jser来说,是个好东西,快快的,自从接触nodejs后,总想弄点东西. 这弄个啥了,一天打开百度音乐盒,哟,自己弄一个如何了,好啊好啊. 后台: nodejs 7 + ko ...
- 学习vue 20天,我写了点东西
往昔 最初团队里使用Angularjs进行开发,刚开始还好,到了项目后期越发感觉Angularjs太重了,以至于后来重构项目时,毅然放弃Angularjs,投入了Vue的怀抱.除了组建团队时,是我搭建 ...
随机推荐
- springcloud干活之服务消费者(feign)
springcloud系列文章的第三篇 本章将继续讲述springcloud的消费者(feign) Spring Cloud Feign是一套基于Netflix Feign实现的声明式服务调用客户端. ...
- 算法-java代码实现归并排序
归并排序 对于一个int数组,请编写一个归并排序算法,对数组元素排序. 给定一个int数组A及数组的大小n,请返回排序后的数组. 测试样例: [1,2,3,5,2,3],6 [1,2,2,3,3,5] ...
- dede 提交表单 发送邮件
第一步:要到dede后台设置好邮箱的资料,并且确定所用的邮箱开启了smtp 第二步:找到/plus/diy.php在 [cce]$query = "INSERT INTO `{$diy-&g ...
- Node之简单的前后端交互
node是前端必学的一门技能,我们都知道node是用的js做后端,在学习node之前我们有必要明白node是如何实现前后端交互的. 这里写了一个简单的通过原生ajax与node实现的一个交互,刚刚学n ...
- label+input实现开关切换效果
Document 主要使用label+input来实现改变left的值,下面是核心代码,意思就是选中的input的兄弟节点.box下的.switch-btn元素的left会变成0px(原来是-37px ...
- 开地址哈希表(Hash Table)的原理描述与冲突解决
在开地址哈希表中,元素存放在表本身中.这对于某些依赖固定大小表的应用来说非常有用.因为不像链式哈希表在每个槽位上有一个"桶"来存储冲突的元素,所以开地址哈希表需要通过另一种方法来解 ...
- Spring的RestTemplata使用
spring-web的RestTemplata是对java底层http的封装,使用RestTemplata用户可以不再关注底层的连接建立,并且RestTemplata不仅支持Rest规范,还可以定义返 ...
- LindDotNetCore~Polly组件对微服务场景的价值
回到目录 Polly是一个开源框架,在github上可以找到,被善友大哥收录,也是.App vNext的一员! App vNext:https://github.com/App-vNext GitHu ...
- 让我们一起爱(装)上Homestead吧
本文是Laravel实战:任务管理系统(一)的扩展阅读原文链接 先来点残酷现实: 真正用过homestead的,一般不会问homestead到底好在哪里 如果你还没有爱上homestead,只能说明 ...
- 在Tomcat中配置连接池和数据源
1.DataSource接口介绍 (1)DataSource 概述 JDBC1.0原来是用DriverManager类来产生一个对数据源的连接.JDBC2.0用一种替代的方法,使用DataSource ...