vuex对象有哪些及用法是什么?
Admin 2021-10-22 群英技术资讯 595 次浏览
今天我们来了解一下vuex,下文会给大家分享vuex中四大对象state、mutations、getters、actions以及他们的用法,对新手学习和理解vuex对象有一定的帮助,感兴趣的朋友就继续往下看吧。
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式(官网地址:https://vuex.vuejs.org/zh/)。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
换成我们大白话来说:Vuex就是一个状态管理模式,可以简单的理解为一个全局对象,然后我们可以修改这个全局对象里面的属性或者添加方法,但是我们不能像传统JS的那种直接赋值形式来修改,我们必须得按照Vuex给我们提供的规则来修改;
Vuex的存在就是应用于解决各个组件之间传值的问题的,说白了就是看我们传统的vue父子组件传值麻烦以及弊端所给我们带来的福利;这一点官网说的很清楚:
提示:本文将以模块导入导出的形式来使用vuex,本文略微有点长,希望耐心的看完,当然有条件的话跟着敲一遍效果会更好!
分别是state、mutations、getters、actions;
state:Vuex中的数据源,我们所需要的公共数据都是存储在这,可以简单理解为一个透明的仓库,可以通过this.$store.state.变量名来访问这个仓库里面的数据源;
mutations:mutations相当于是这把仓库的钥匙,只有通过提交mutations才能进行修改数据源操作,也就是说你想更改这个仓库里面的数据就只有通过mutations来进行修改(this.$store.commit("方法名"));
getters:getters类似于vue中的computed属性,getters的返回值会根据state中所依赖的值的状态修改来进行改变,如果getters中依赖的state中的值没有变化,直接读的是缓存,如果有变化这里也会发生相应的变化,可以用于监听state的值的变化;这里的getters可以理解为state这个仓库的保安,如果state的数据发生变化,这个保安就会采取相应措施进行相应变化,如果没有发生变化,则啥事没有则继续混吃等死(哈哈哈,不知道比喻恰不恰当,但是是这个意思,大家理解就好,别杠精)
actions:actions和mutations很类似,只是mutations官方规定只能进行同步操作,而actions里是可以进行异步操作的;也就是说我们需要进行异步操作需要在actions中来进行,然后就是actions提交的是mutations,而不是直接修改状态的,也就是说进入这个仓库修改数据,要先去拿到钥匙才能修改,所以actions是提交给mutations再去执行mutations的方法的:
首先我们新建一个项目,搭建vue的环境我们这里就不多赘述了,毕竟本文是讲述vuex的;先在项目中安装vuex:
安装vuex命令:npm install vuex --save
安装完vuex之后我们在src的目录下新建一个vuex文件夹,同时在vuex文件夹中新建一个store.js文件:
store.js:
import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex); const state={ number:1 } export default new Vuex.Store({ state, })
然后我们在main.js中引用store.js,并将实例化对象的时候加入store对象
main.js
import Vue from 'vue' import App from './App' import router from './router' //引用store.js import store from './vuex/store' Vue.config.productionTip = false /* eslint-disable no-new */ new Vue({ el: '#app', router, //实例化的时候加入store对象 store, components: { App }, template: '<App/>' })
然后修改一下我们的App.vue文件
App.vue
<template> <div id="app"> <img src="./assets/logo.png"> //视图层加数据方便观察 <p>{{this.$store.state.number}}</p> </div> </template> <script> export default { name: 'App' } </script> <style> #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
通过上述代码我们可以看到,我们在App.vue中加入了一个p标签,vuex规定:如果我们需要读取vuex中的数据,也就是state的数据源仓库,我们必须通过this.$store.state.变量名访问
如果我们需要修改vuex中的数据源,我们可以通过提交mutations来进行修改;
首先我们需要在我们的视图层加个按钮来控制:
App.js
<template> <div id="app"> <img src="./assets/logo.png"> <p>{{$store.state.number}}</p> //加个按钮触发事件修改数据源 <button @click="add">按钮</button> </div> </template> <script> export default { name: 'App', methods:{ add(){ //要修改数据源就要根据vuex规定的方法来 this.$store.commit('addFunction'); } } } </script> <style> #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
然后修改我们的store.js:
import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex); const state={ number:1 } //添加mutations对象,state参数能获取到上面的state const mutations={ addFunction(state){ return state.number+=1; } } //这里一定要记得要加入到实例中,不然会报错 export default new Vuex.Store({ state, mutations })
我们可以很直观的看到,通过this.$store.commit('方法名')来提交mutations修改数据源,当然我们的mutations也是可以接收参数的,第一个参数为mutations的方法名,第二个参数为mutations需要接收的参数,这样我们的mutations就变得更加的灵活;
getters类似于vue的computer用法,可以监听state数据源这个仓库的数据变化,如果getters依赖state的数据发生了变化,getters中依赖的数据发生了变化state也会发生变化
首先我们可以在store.js中添加以下代码:
import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex); const state={ number:1 } const getters={ //通过方法触发 state是上面的state对象,能读取state的值 addFunction(state){ return state.number++; } } export default new Vuex.Store({ state, //这里一定要记得在实例化的时候加入对象 getters })
App.vue中的视图我们可以这样更改:
<template> <div id="app"> <img src="./assets/logo.png"> <p>页面的值:{{$store.state.number}}</p> //加入一个标签跟页面的值做对比 <p>我的getters的值:{{$store.getters.addFunction}}</p> </div> </template> <script> export default { name: 'App', } </script> <style> #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
通过上述代码以及视图层我们可以清晰的看到,当我们操作了getters的时候,触发了getters的addFunction方法,addFunction方法会改变state.number的值,这个时候number的值已经为2了,所以页面上会显示值为2,因为++在后,所以getters此时的值为1,也就是说当getters依赖的state.number的值在getters中发生变化的时候,state.number就会发生变化,如果state.number没有发生变化,此时getters会优先读缓存;
actions对象里面主要是进行异步操作,类似于mutations,不同的是actions通过提交mutations来进行更改数据,而不是直接变更数据状态;
首先我们可以更改store.js中的代码:
import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex); const state={ number:1 } const mutations={ addFunction(state){ return state.number++; } } const getters={ addFunction(state){ return state.number++; } } //context是具有store实例一样的属性和方法的对象 const actions={ addFunction(context){ context.commit("addFunction"); } } export default new Vuex.Store({ state, mutations, getters, //这里记得要在实例化的时候要加上 actions })
App.vue中代码修改为:
<template> <div id="app"> <img src="./assets/logo.png"> <p>页面的值:{{$store.state.number}}</p> <button @click="add">按钮</button> </div> </template> <script> export default { name: 'App', methods:{ add(){ //actions中通过this.$store.dispatch来提交mutations进行修改 this.$store.dispatch("addFunction") } } } </script> <style> #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
在项目开发中,可能会有很多数据或者参数我们可能需要多次读取或者修改,像购物车等类似功能,这个时候我们的就可以用vuex来实现;vuex毕竟只是一个状态管理模式,状态管理模式是给我们提供方便的,但不是必需的,因为状态管理能做的事通过其他途径和办法也能实现。其实个人觉得vuex跟localStorange有点相似,都是用于存储和修改数据,为了解决跨页面数据丢失问题;
关于vuex对象及用法,还有vuex使用场景等等,相信大家应该都了解了吧,希望大家阅读完这篇文章能有所收获。最后,想要了解更多vuex的的内容,大家可以关注其它的相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
clipboard.js是一款轻量级的实现复制文本到剪贴板功能的JavaScript插件,本文就详细的介绍一下如何使用,感兴趣的可以了解一下
这篇文章主要为大家详细介绍了uniapp电商小程序实现订单30分钟倒计时,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
下拉框菜单相信大家都比较熟悉,那么鼠标经过显示下拉框效果是怎么做的呢?这篇文章就给大家分享一下用JavaScript实现鼠标经过显示下拉框代码,感兴趣的朋友可以参考,实现效果和代码如下。
一、开启多进程constos=require('os');constcp=require('child_process');constforkList={};constforkPrefix='fork_';letcpusLen=os.cpus().length;letport=9562;for(vari=1;i<=cpusL
这篇文章主要为大家详细介绍了jQuery实现表格行数据滚动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008