摘要:一前言本次接受一个系统,要求是能够接入数据源得到数据集对数据集进行处理展现为数据的可视化,这一个系统为了接入公司自身的产品,后端技术采用,前端采用的项目架构方式,作为的状态管理,是尤为重要的部分。
一、前言
本次接受一个BI系统,要求是能够接入数据源-得到数据集-对数据集进行处理-展现为数据的可视化,这一个系统为了接入公司自身的产品,后端技术采用spring boot,前端采用vue+vuex+axios的项目架构方式,vuex作为vue的状态管理,是尤为重要的部分。这里,我将vuex如何运作和使用做一次总结,有错的地方,望多多提点。
二、vuex简单使用安装vuex
cnpm install vuex --save
在src目录下建立文件夹,命名为store,建立index.js
如图所示:
在index.js中引入vue和vuex状态管理,并导出vuex,代码如下:
import Vue from "vue" import Vuex from "vuex" Vue.use(Vuex) const store = new Vuex.Store({ state: { token: 0 }, }) export default store;
在main.js中引入刚刚创建好的store并作为vue的store
import Vue from "vue" import App from "./App.vue" import store from "./store/index" Vue.config.productionTip = false new Vue({ render: h => h(App) , store }).$mount("#app")
获得store里的token
在vue的组件中,想要获得vuex里的全局数据,可以把vue看做一个类,在其下面有许多属性,其中有我们刚刚注入的vuex,如图
我们可以看到vue他本身就是一个json,在其下有$store这个对象,而$store下又有state,state下得就是我们存储在vue中的全局数据,
在组件中通过this.$store.state.token即可获得我们的数据。
有时候我们需要在获得的数据做一些简单的过滤或者处理的时候,getters就起到作用了。
代码如下
getters:{ getToken(state){ return state.token; }
同直接获取token的方式一样。getters也已经挂载到了$store下,故,我们可以通过this.$store.state.getters.getToken的方式,调用
其函数。 但vuex为我们提供了mapGetters能够将其映射到对应的getters的方法上去,用法如下所示
import {mapGetters,mapActions} from "vuex" export default { name: "app", components: { HelloWorld }, computed:{ ...mapGetters(["getToken"]) }, mounted() { console.log(this.getToken) console.log(this.$store.getters.getToken) }, }
映射出来的getters仍然挂载在vue上,如图所示
四、vuex的核心概念之mutations与actions我们可以吧mutations理解成一个事件函数,而actions就是触发器,通过actions,发起动作。
简单实例代码如下。
mutations:{ setToken(state,n){ state.token=state.token+n; } }, actions:{ setToken({commit},n){ commit("setToken",n) } }
在组件中的使用,同getters的用法,
代码如下
import {mapGetters,mapActions} from "vuex" export default { name: "app", components: { HelloWorld }, computed:{ ...mapGetters(["getToken"]) }, mounted() { console.log(this) console.log(this.setToken(1)) console.log(this.getToken) },methods:{ ...mapActions(["setToken"]) },
在vue的json中,同样可以找到相同的属性。
五、vuex核心概念之mudulesvuex允许我们将store分为不同的模块,每个多带带的模块具备getters,state,mutations,actions这四个store核心,
需要注意的是如果在模块内部加入了namesapced:true这一个属性。在取值的时候需要做一点细微的变动,通过mapGetters火mapActions映射时需要将模块名作为路劲,来获得该模块的getters,和actions,模块化代码如下
import Vue from "vue" import Vuex from "vuex" Vue.use(Vuex) const moduleA = { namespaced:true, state: { a:1 }, mutations: { }, actions: { }, getters: { geta(state){ return state.a; } } } const moduleB = { namespaced:true, state: { b:1}, mutations: { }, actions: {} } const store = new Vuex.Store({ state: { token: 0 }, getters:{ getToken(state){ return state.token; }, } , mutations:{ setToken(state,n){ state.token=state.token+n; } }, actions:{ setToken({commit},n){ commit("setToken",n) } }, modules: { a: moduleA, b: moduleB }, }) export default store;
在组件中获得模块A的值得时候,我们来看一下geta这个getters属性,在vue中的状态,如图所示
geta为模块a下得getters属性,在获取的时候就需要这样
computed:{ // ...mapGetters(["getToken"]) ...mapGetters("a",["geta"]) }, mounted() { console.log(this) console.log(this.geta)
而如果模块没有命令空间的话,vuex会自动将模块内的getters,actions注入为全局的,直接按照原来个获取方式就可以了。
六、总结这是我对vuex的基本用法和基本理解方式,vuex当然不可能局限于此,此处只列举了最简单的,做个总结的同时也等同于记下,据说vue3块出了,是用ts重写的vue,到时再去看看,vue3又有了哪些变化,和哪些可取之处。本文所写,有不对的地方,大家多多提出来。共同进步。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/98890.html
摘要:在中添加原型属性通过实现任意组件传递参数在挂载声明周期函数中监听自定义事件给传递数据由触发一个事件,在接收数据的组件中监听该事件状态管理随着组件的增加,通过以上方式共享数据,会越来越复杂,提供了状态管理插件。 vue 状态管理(一) 父子组件之间往往使用props和 $emit 实现数据共享,任意组件可通过bus(一个vue实例)作为桥梁,实现数据共享。当项目中组件越来越...
摘要:说实在话,我在阅读文档的时候,也很难以去理解,甚至觉得没有使用它我也可以。介绍那么到底是什么引用官网的说法就是是一个专为应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。 前言 先说句前话,如果不是接触大型项目,不需要有多个子页面,不使用vuex也是完全可以的。 说实在话,我在阅读vuex文档的时候,也很难以去理解v...
摘要:说实在话,我在阅读文档的时候,也很难以去理解,甚至觉得没有使用它我也可以。介绍那么到底是什么引用官网的说法就是是一个专为应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。 前言 先说句前话,如果不是接触大型项目,不需要有多个子页面,不使用vuex也是完全可以的。 说实在话,我在阅读vuex文档的时候,也很难以去理解v...
摘要:说实在话,我在阅读文档的时候,也很难以去理解,甚至觉得没有使用它我也可以。介绍那么到底是什么引用官网的说法就是是一个专为应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。 前言 先说句前话,如果不是接触大型项目,不需要有多个子页面,不使用vuex也是完全可以的。 说实在话,我在阅读vuex文档的时候,也很难以去理解v...
阅读 2064·2021-11-24 09:39
阅读 1496·2021-10-11 10:59
阅读 2455·2021-09-24 10:28
阅读 3340·2021-09-08 09:45
阅读 1242·2021-09-07 10:06
阅读 1580·2019-08-30 15:53
阅读 2032·2019-08-30 15:53
阅读 1396·2019-08-30 15:53