VueX--VUE核心插件
admin
2023-08-16 06:32:12
0

使用VueX方法 1.安装vuex模块 npm install vuex --save
2.作为插件使用 Vue.use(Vuex)
3.定义容器 new Vuex.Store({
这里面放定义状态代码
})
4.注入根实例
VueX--VUE核心插件
文章图片
vuex代码,一般放在src/store/index.js文件中
如何在vuex中定义状态数据?

例:
let store = new Vuex.Store({ //创建Vuex实例
//这里定义状态数据
state: {
count: 100
}
});
vuex核心概念 store:类似容器,包含应用的大部分状态;
注意:
* 一个页面只能有一个store
* 状态存储是响应式的
* 不能直接改变store中的状态,唯一途径显示地提交mutations
State:包含所有应用级别状态的对象
Getters:在组件内部获取store中状态的函数
Mutations:唯一修改状态的事件回调函数
Actions:包含异步操作、提交mutation改变状态
Modules:将store分割成不同的模块
如何获取定义的状态数据? 在需要获取数据的单页面文件组件中,使用以下方法:
VueX--VUE核心插件
文章图片
如何改变vuex容器中(store)如的值? 方法1.改变非异步(不通过ajax)的值 使用mutations属性,处理同步数据修改
例:
vuex对象中写:
VueX--VUE核心插件
文章图片
【VueX--VUE核心插件】在单页面文件组件中调用
VueX--VUE核心插件
文章图片
注意:
mutations不能直接调用;
调用方法:
$store.commit("写mutations中的回调函数名");
这个方法,一个参数的时候,是直接调用mutations函数。
第二个参数,代表传入mutations函数的参数。
第二个参数,可以是1个,多个的时候,传一个对象;
如:
$store.commit("写mutations中的回调函数名",{n:2});
这样在mutations:中就可以接收了
commit的对象形式写法
$store.commit({
type:'写mutations中的回调函数名',
de:10 //这个就是第二个参数,key名随便起
})
方法2.改变异步(ajax获取)的值 使用actions:处理异步数据修改
//要先写好mutations的方法
mutations:{
addIncrement(state){
state.count +=1;
}
},
/*
当遇到数据是通过ajax异步请求过来的,这时数据会有延迟
这种时候,就需要使用actions来提交mutations中的回调函数
*/
actions:{
//函数名随便写,参数是一个对象,和store对象的方法属性都一样的对象;
addAction(context){
setTimeout(()=>{
//通过context对象,可以使用commit方法,参数输入mutations中的函数名
context.commit('addIncrement');
},1000);
}
}
调用actions中的函数,方法如下
dispatch传参的格式方法,与this.$store.commit()一模一样
this.$store.dispatch('addAction');
actions中的函数可以相互调用传值;
例:
actions:{
//函数名随便写,参数是一个对象,和store对象的方法属性都一样的对象;
addAction(context){
setTimeout(()=>{
//通过context对象,可以使用commit方法,参数输入mutations中的函数名
context.commit('addIncrement');
//这里调用了下面的函数
context.dispatch('testAction',{test:'测试'});
},1000);
},
testAction(context,obj){//传值正常传
//可以打印出'测试的数据'
console.log(obj.test);
}
}
这里说明一下actions传值的另一种方法
actions:{
//函数名随便写,参数是一个对象,和store对象的方法属性都一样的对象;
/*
这个context参数,可以使用es6的结构赋值方法写
直接传一个对象形式{commit,dispatch} 把需要的方法直接写到里面,不用传context去调用对应的方法
这样写更方便。
es6的结构赋值:把一个对象里面的属性,直接放到对象中;
*/
addAction({commit,dispatch}){
setTimeout(()=>{
//通过context对象,可以使用commit方法,参数输入mutations中的函数名
commit('addIncrement');
dispatch('testAction',{test:'测试'});
},1000);
},
testAction(context,obj){
console.log(obj.test);
}
}
getter计算状态 作用:关于状态数据中,一些对数据的处理(判断/过滤)等,都在getter属性中处理。
写法:在vuex对象中写
getters:{
filterCount(state){//state就是状态对象
//在这里做count的判断
return state.count >= 120 ? 120 : state.count;
}
}
调用方法:
computed:{//在计算属性中取vuex定义的状态数据
//getter的调用方法,就是在计算属性中,另定义一个函数,在这个函数中调用getter中判断过的值
num2(){
//$store中有getters属性,可以获取getter中的filterCount的值
return this.$store.getters.filterCount;
}
}
HTML显示方法:
VueX--VUE核心插件
文章图片
Vuex辅助函数 mapState:
当一个组件需要获取多个状态时候,将这些状态都声明为计算属性会有些重复和冗余。为了解决这个问题,我们可以使用 mapState 辅助函数帮助我们生成计算属性。
mapGetters:
辅助函数仅仅是将 store 中的 getter 映射到局部计算属性。
mapMutations:
将 store 中的 mutations 映射到局部计算属性。
mapActions:
将 store 中的 actions 映射到局部计算属性。

相关内容

热门资讯

超... 本文目录导航: 超级云计算是什么 怎么做难看的PPT 1、...
谢... 本文目录导航: 请问云主机是什么 云主机有什么好处 具体的教程,谢谢! 云...
w... 本文目录导航: wps是什么意思 ppt的新配置designer和morp...
大... 本文目录导航: 大专学什么专业务工率高? 未来十年务工率最高的几大专业都是...
软... 本文目录导航: 软件技术专升本可以报什么专业 云计算专升本可以报医学吗 ...
云... 本文目录导航: 云计算务工前景 云计算务工方向及前景怎样样 ...
学... 本文目录导航: 学云计算进去无能嘛 云计算技术与运行是干什么的 ...
中... 本文目录导航: 如何了解云计算,中国的云计算产业开展现状如何 云计算未来几...
云... 本文目录导航: 云计算1+x证书含金量 云计算须要考什么证书 ...
云... 本文目录导航: 云计算股票龙头股票有哪些? 普通云计算概念龙头股有哪些?...
大... 本文目录导航: 大专云计算技术运行务工方向 大专毕业证上是物联网,实践学习...
大... 本文目录导航: 大数据云计算有必要升本吗 内蒙古大专云计算技术与运行专业升...
9... 本文目录导航: 99%学霸假期逆袭必看网站 99%学霸假期逆袭必看网站 ...
云... 本文目录导航: 云计算属于哪个专业 云计算属于什么专业 计...
计... 本文目录导航: 计算机二级MSOffice上机操作题及答案 想做一篇关于解...
A... 本文目录导航: AI能否会彻底扭转上流职业市场,如律师、会计师和医师? A...
人... 本文目录导航: 人工智能芯片产业链有哪些? 更多本行业钻研剖析详见前瞻产业...
人... 本文目录导航: 人工智能会带来哪些风险? 或许有一天,人工智能机器人将取代...
a... 本文目录导航: ai智能写作软件哪个好 ai智能写作软件有哪些?ai智能对...
自... 本文目录导航: 自考本科计算机专业难吗 自考计算机专业须要考哪些科目 ...