Vue基础21之Vuex第二节
创始人
2024-06-03 22:23:27
0

Vue基础21

  • Vuex
    • 多组件共享数据
      • Calculation.vue
      • Persons.vue
      • src/store/index.js
    • vuex模块化+namespace
      • 模块化
        • src/store/index.js
        • Calculation.vue
        • Persons.vue
        • App.vue
      • 发送Ajax请求处理并拆分store
        • 请求
        • src/store/personOptions.js
        • src/store/countOptions.js
        • main.js
        • src/store/index.js
        • Persons.vue
        • Calculation.vue
        • App.vue
    • 总结:模块化+命名空间

Vuex

多组件共享数据

在这里插入图片描述

Calculation.vue

Persons.vue

src/store/index.js

//该文件用于创建Vuex中最为核心的store
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//应用vuex插件
Vue.use(Vuex)//准备actions——用于响应组件中的动作
const actions={addOdd(context,value){if(context.state.sum%2){console.log("actions中的addOdd被调用了")context.commit("Addmore",value)}},addWait(context,value){setTimeout(()=>{console.log("actions中的addWait被调用了")context.commit("Addmore",value)},500)}
}
//准备mutations——用于操作数组(state)
const mutations={Addmore(state,value){console.log("mutations中的Addmore被调用了")state.sum+=value},Deduce(state,value){console.log("mutations中的Deduce被调用了")state.sum-=value},AddPerson(state,value){state.personList.unshift(value)}
}
//准备state——用于存储数组
const state={sum:0,school:"幸福大学",subject:"计算机",personList:[{id:"001",name:"张三"}]
}//准备getters——用于将state中的数据进行加工
const getters={bigSum(state){return state.sum*10}
}//创建并暴露store
export default new Vuex.Store({actions,mutations,state,getters
})

请添加图片描述

vuex模块化+namespace

在这里插入图片描述

模块化

src/store/index.js

//该文件用于创建Vuex中最为核心的store
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//应用vuex插件
Vue.use(Vuex)//求和相关的配置
const countOptions={namespaced:true,//准备actions——用于响应组件中的动作actions:{addOdd(context,value){if(context.state.sum%2){console.log("actions中的addOdd被调用了")context.commit("Addmore",value)}},addWait(context,value){setTimeout(()=>{console.log("actions中的addWait被调用了")context.commit("Addmore",value)},500)}},//准备mutations——用于操作数组(state)mutations:{Addmore(state,value){console.log("mutations中的Addmore被调用了")state.sum+=value},Deduce(state,value){console.log("mutations中的Deduce被调用了")state.sum-=value},},//准备state——用于存储数组state:{sum:0,school:"幸福大学",subject:"计算机",},//准备getters——用于将state中的数据进行加工getters:{bigSum(state){return state.sum*10}}
}//人员相关的配置
const personOptions={namespaced:true,actions:{addPersonWang(context,value){if(value.name.indexOf("王")==0){context.commit("AddPerson",value)}else{alert("添加的必须是姓王的人!")}}},mutations:{AddPerson(state,value){state.personList.unshift(value)}},state:{personList:[{id:"001",name:"张三"}]},getters:{firstPersonName(state){return state.personList[0].name}}
}//创建并暴露store
export default new Vuex.Store({modules:{countAbout:countOptions,personAbout:personOptions}
})

Calculation.vue

Persons.vue

App.vue

请添加图片描述

发送Ajax请求处理并拆分store

在这里插入图片描述

请求

https://api.uixsj.cn/hitokoto/get?type=social
随机生成语录

src/store/personOptions.js

//人员相关的配置
import axios from "axios";
import {nanoid} from 'nanoid'
export default {namespaced:true,actions:{addPersonWang(context,value){if(value.name.indexOf("王")==0){context.commit("AddPerson",value)}else{alert("添加的必须是姓王的人!")}},addPerson(context){axios.get("https://api.uixsj.cn/hitokoto/get?type=social").then(response=>{context.commit("AddPerson",{id:nanoid(),name:response.data})},error=>{alert(error.message)})}},mutations:{AddPerson(state,value){state.personList.unshift(value)}},state:{personList:[{id:"001",name:"张三"}]},getters:{firstPersonName(state){return state.personList[0].name}}
}

src/store/countOptions.js

//求和相关的配置
const countOptions={namespaced:true,//准备actions——用于响应组件中的动作actions:{addOdd(context,value){if(context.state.sum%2){console.log("actions中的addOdd被调用了")context.commit("Addmore",value)}},addWait(context,value){setTimeout(()=>{console.log("actions中的addWait被调用了")context.commit("Addmore",value)},500)}},//准备mutations——用于操作数组(state)mutations:{Addmore(state,value){console.log("mutations中的Addmore被调用了")state.sum+=value},Deduce(state,value){console.log("mutations中的Deduce被调用了")state.sum-=value},},//准备state——用于存储数组state:{sum:0,school:"幸福大学",subject:"计算机",},//准备getters——用于将state中的数据进行加工getters:{bigSum(state){return state.sum*10}}
}
export default countOptions

main.js

import Vue from 'vue'import App from './App'
//引入vue-resource插件
import vueresource from 'vue-resource'//引入store
import store from './store'Vue.config.productionTip = false
//使用vue-resource插件
Vue.use(vueresource)new Vue({el: "#app",render: h => h(App),store,beforeCreate() {Vue.prototype.$bus = this}
})

src/store/index.js

//该文件用于创建Vuex中最为核心的store
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//应用vuex插件
Vue.use(Vuex)//引入
import countOptions from "@/store/countOptions";
import personOptions from "@/store/personOptions";//创建并暴露store
export default new Vuex.Store({modules:{countAbout:countOptions,personAbout:personOptions}
})

Persons.vue

Calculation.vue

App.vue

请添加图片描述

总结:模块化+命名空间

  1. 目的:让代码更好维护,让多种数据分类更加明确
  2. 修改store.js
const countAbout={namespaced:true,//开启命名空间state:{x},mutations:{...},actions:{...},getters:{bigSum(state){return state.sum*10}}
}const personAbout={namespaced:true,//开启命名空间state:{...},mutations:{...},actions:{...}
}const store=new Vuex.Store({modules:{countAbout,personAbout}
})
  1. 开启命名空间后,组件中读取state数据
//方式一:自己直接读取
this.$store.state.personAbout.list
//方式二:借助mapState读取
...mapState('countAbout',['sum','school','subject']),
  1. 开启命名空间后,组件中读取getters数据
//方式一:自己直接读取
this.$store.getters['personAbout/firstPersonName']
//方式二:借助mapGetters读取
...mapGetters('countAbout',['bigSum']),
  1. 开启命名空间后,组件中调用dispatch
//方式一:自己直接dispatch
this.$store.dispatch('personAbout/addPersonWang',person)
//方式二:借助mapActions读取
...mapActions('countAbout',{incrementOdd:'jiaOdd',incrementWait:'jiaWait'}),
  1. 开启命名空间后,组件中调用commit
//方式一:自己直接commit
this.$store.commit('personAbout/ADD_PERSON',person)
//方式二:借助mapMutations读取
...mapMutations('countAbout',{incrementOdd:'JIA',decrement:'JIAN'}),

相关内容

热门资讯

延续百年的艺术生命 转自:光明日报    布勒东(1896—1966)资料图片    马格利特作品《人类的境况》资料图片...
崇义章源钨业股份有限公司关于参... 证券代码:002378 证券简称:章源钨业 公告编号:2025-030崇义章源钨业股份有限公司关于...
成都市新筑路桥机械股份有限公司... 证券代码:002480 证券简称:新筑股份 公告编号:2025-037成都市新筑路桥机械股份有限公...
中粮糖业控股股份有限公司关于参... 证券代码:600737 证券简称:中粮糖业 公告编号:2025-014中粮糖业控股股份有限公司关于...
获格莱美四项提名歌手参加我是歌... 【#获格莱美四项提名歌手参加我是歌手# #3名国际歌手谈参加我是歌手#】5月14日,#歌手首发阵容官...
教育部禁止中小学生用AI写作业... 【#教育部禁止中小学生用AI写作业##教育部给学生的AI依赖立规矩#】5月12日,教育部基础教育教学...
中国建筑全资子公司新增一项41... (转自:快查一企业中标了)快查APP显示,中国建筑相关公司中国建筑一局(集团)有限公司于2025年5...
收盘:美股涨跌不一 道指连续第... 查看最新行情   北京时间5月15日凌晨,美股周三收盘涨跌不...
河南蓝天燃气股份有限公司关于使... 证券代码:605368 证券简称:蓝天燃气 公告编号:2025-034转债代码:111017 转债...
秘鲁总统任命前司法部长阿拉纳为... 秘鲁总统博鲁阿尔特(左)和新任总理爱德华多·阿拉纳(右)在宣誓仪式上新华社利马5月14日消息,秘鲁总...
原油:WTI下跌 美国原油库存...   原油下跌,此前有政府报告显示,美国原油库存创两个月来最大增幅,抵消了世界两大经济体贸易战暂停带来...
长江精工钢结构(集团)股份有限... 股票简称:精工钢构 股票代码:600496 编号:临2025-065转债简称:精工转债 转债代码...
山东高速路桥集团股份有限公司关... 证券代码:000498 证券简称:山东路桥 公告编号:2025-42山东高速路桥集团股份有限公司关...
丽珠医药集团股份有限公司关于回... 证券代码:000513、01513 证券简称:丽珠集团、丽珠医药 公告编号:2025-042丽珠医药...
因存在安全隐患,福特公司召回约... 央视记者当地时间5月14日获悉,福特汽车公司宣布,由于存在可能导致车辆在行驶过程中丧失制动功能、增加...
“土原料”变“潮产品” 青海兄弟乳业生物科技有限公司张成龙获“2025 IMW世界甜品巧克力&手工冰淇淋大赛暨2025意大利...
顺我者富 逆我者贫——解读特朗...   美国众议院共和党提出的新税收法案草案中,富人和企业投资者明显受益,而移民、顶尖私校等被特朗普长期...
青稞“链”上黄金道 产业升级加... 5月13日,海东市互助土族自治县青稞产业园内,青稞香飘满链。生产线轰鸣声中,金黄青稞粒经低温烘焙化作...
青海多措并举维护广告市场良好秩... 本报讯 (记者 董洁) 5月14日,记者从青海省市场监督管理局获悉,为切实维护全省广告市场秩序,保障...
厦门钨业股份有限公司关于向控股... 证券代码:600549 证券简称:厦门钨业 公告编号:临-2025-046厦门钨业股份有限公司关于...