当前位置: 首页 > news >正文

网站建设项目开发书广州seo关键词

网站建设项目开发书,广州seo关键词,做p2p网站费用,关于网站设计文章目录 Vue之调用store的action(包含getter调用)调用store的action方法一:Promise 链式调用方法二:async/await方法三:Promise.all()同时执行 调用store的getter方法一:this.$store.getters调用方法二:mapGetters调用…

文章目录

  • Vue之调用store的action(包含getter调用)
    • 调用store的action
      • 方法一:Promise 链式调用
      • 方法二:async/await
      • 方法三:Promise.all()同时执行
    • 调用store的getter
      • 方法一:this.$store.getters调用
      • 方法二:mapGetters调用
    • 示例代码:

Vue之调用store的action(包含getter调用)

调用store的action

方法一:Promise 链式调用

this.$store.dispatch('actionOne').then(() => {return this.$store.dispatch('actionTwo');}).then(() => {return this.$store.dispatch('actionThree');}).catch(error => {// 处理错误console.error(error);});

这种方式会依次触发这三个 action,并在每个 action 完成后再触发下一个 action。

方法二:async/await

async someMethod() {try {await this.$store.dispatch('actionOne');await this.$store.dispatch('actionTwo');await this.$store.dispatch('actionThree');} catch (error) {// 处理错误console.error(error);}
}

使用 async/await 可以让代码看起来更像同步操作,但依然是异步执行。这样的方式也可以让后续的 action 等待前一个 action 完成后再执行。

方法三:Promise.all()同时执行

Promise.all([this.$store.dispatch('actionOne'), this.$store.dispatch('actionTwo'), this.$store.dispatch('actionThree')]).then(results => {// 所有异步操作都成功完成,results 是包含每个异步操作结果的数组console.log(results);}).catch(error => {// 至少有一个异步操作失败console.error(error);});

总结:选择哪种方式取决于你的需求,以及这些 action 之间是否有依赖关系。如果它们之间是独立的,可以同时执行,那么使用 Promise.all() 可能更合适。如果需要按顺序执行,可以使用 Promise 链式调用或 async/await。

调用store的getter

方法一:this.$store.getters调用

如果你在 Vue.js 组件中的 methods 部分想要调用 Vuex store 中的 getter,你可以通过使用 this.$store.getters 来访问。假设你有一个名为 getCityList 的 getter,你可以这样在组件的 methods 中调用它:

export default {methods: {someMethod() {// 调用 Vuex store 中的 getCityList getterconst cityList = this.$store.getters.getCityList;}},// 其他组件选项...
};

在上面的例子中,this.$store.getters.getCityList 就是访问 Vuex store 中 getCityList getter 的方法。

方法二:mapGetters调用

确保你使用的 getter 名称和 Vuex store 中的命名一致。如果你在使用模块化的 Vuex store,也需要考虑模块的命名空间。在这种情况下,你可以使用 mapGetters 辅助函数,这将自动处理命名空间。

import { mapGetters } from 'vuex';export default {computed: {// 使用 mapGetters 辅助函数将两个 getter 映射到计算属性...mapGetters(["getCityList", "getCountryList"])},methods: {someMethod() {// 直接访问映射后的计算属性const cityList = this.getCityList;const countryList = this.getCountryList;}},// 其他组件选项...
};

上面的代码假设你已经在组件中使用 mapGetters 映射了 getCityList和getCountryList的getter。

示例代码:

src/store/modules/city.js

//接口
import { getCityListAPI } from "@/api/commonAPI.js";const state = {cityList: []
}const getters = {getCityList: state => {var list;//先从session中获取,获取不到再从state里获取if (sessionStorage.getItem('cityList')) {list = JSON.parse(sessionStorage.getItem('cityList'));} else {list = state.cityList;}return list;}
}const mutations = {["SET_CITY_INFO"](state, data) {state.cityList = data === null ? {} : data;//设置进session中sessionStorage.setItem('cityList',JSON.stringify(data))}
}const actions = {//调用接口获取地市放进session中setCityList({commit}) {return new Promise(resolve => {getAllCityListAPI().then(res => {commit("SET_CITY_INFO", res);resolve()});})}
}export default {state,getters,mutations,actions
};

src/store/index.js

import Vue from "vue";
import Vuex from "vuex";
import createPersistedState from "vuex-persistedstate";
import city from "./modules/city";Vue.use(Vuex);export default new Vuex.Store({modules: {city},plugins: [createPersistedState({ storage: window.sessionStorage })]
});

调用action

Promise.all([this.$store.dispatch('setCityList')).then(results => {console.log("获取地市列表信息----------------");}).catch(error => {// 至少有一个异步操作失败console.error(error);});

调用getter

export default {methods: {someMethod() {// 调用 Vuex store 中的 getCityList getterconst cityList = this.$store.getters.getCityList;}},// 其他组件选项...
};
http://www.yayakq.cn/news/139535/

相关文章:

  • 成都市网站建设服务商千锋教育的it培训怎么样
  • 广西柳州网站建设小程序公司慈溪做无痛同济 amp 网站
  • 网站中下滑菜单怎么做网页设计与制作课程设计报告小结
  • 社区网站推广方案宁波网络营销策划公司
  • 沈阳网站关键词优化排名网站源代码下载工具
  • 网站加百度地图建设网站开发的语言有哪些
  • 英文外贸网站企业查询猫
  • 中国城乡建设部网站房贴文件网站建设公司哪个好一点
  • 微软的网站开发软件申请网站建设经费的请示
  • 网站的可用性淘宝客建网站
  • 做跳转链接到自己的网站wordpress 分类目录–标签转换器
  • 新闻类网站html模板免费下载天眼通查公司查询入口
  • 专门做算法项目的网站网站建设 提升和扩大
  • 怎样看一个网站是不是织梦做的淄博企业网站排名优化
  • 手机网站开发利用流程企业信息化管理系统
  • 安庆做网站的公司网站广告设计怎么做
  • 引擎网站推广法人工智能工程师
  • 网站建设推广培训制作相册的软件
  • 动易网站首页错位网站建设和推广的话术
  • 网站建设管理工作交流发言材料wordpress getfooter
  • 怎样做网站个人简介免费咨询在线医生问答
  • 酒店网站怎么做潍坊百度网站快速排名
  • 移动建站公司郑州网站设计
  • 宿迁网站建设价位qq是哪一个软件公司开发的
  • 中国少数民族网站建设东莞网站seo价格
  • 做游戏网站年入百万网站开发与移动互联
  • 网站制作河南济南济南网站建设公司
  • 个人网站是商业的吗做网站建设的企业还有那些
  • 网站开发立项报告谷歌网站开发语言
  • 爱站网影视排行榜可以自己制作图片的软件