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'}),

相关内容

热门资讯

以军袭击致加沙42名领取人道援... 当地时间7月3日晚,加沙地带卫生部门发布声明称,以军自当天凌晨以来在加沙地带的军事行动共导致92名巴...
乡土大地上的春华与秋实 20世纪90年代,兰学良在大通回族土族自治县民族中学办公室。本文配图均由兰学良提供。1987年,兰学...
构建以绿色发展为导向的课程思政... 徐向峰绿色发展理念强调人与自然和谐共生,是习近平生态文明思想的重要组成部分,是推动经济社会向绿色转型...
集结!直击“环青赛大本营”的热... 本报记者 张慧慧7月3日17时许,2辆大巴车陆续抵达青海多巴国家高原体育训练基地,远道而来的各支车队...
青海全面上线“医保钱包”实现职... 本报讯 (记者 郭靓) 7月3日,青海省医疗保障局传来好消息,7月1日起,在全省范围正式上线“医保钱...
Ondo 与 Pantera ... 吴说获悉,Ondo Finance 与 Pantera Capital 向 Axios 表示,双方将...
光影铸史 抗战留痕   李伯绅  《光影山河:电影与抗战》 秦翼 张丹 著 江苏人民出版社 江苏凤凰教育出版社  抗战时...
川渝两地共同为跨区域环境损害追... 转自:成都日报锦观川渝两地共同为跨区域环境损害追责“立新规” 本报讯 (成都日报锦观新闻记者 ...
关注“立园满园”行动 这场参观... 转自:成都日报锦观关注“立园满园”行动 这场参观考察走进新都区 近日,市委老干部局组织22位市...
中科软科技股份有限公司关于持股... 证券代码:603927 证券简称:中科软 公告编号:2025-023中科软科技股份有限公司关于持股5...