极乐门资源网 Design By www.ioogu.com
背景:项目中有多个组件调用同一接口,为提高代码可维护性,需要封装公共方法
直接return 接口调用的结果
export function getAll() { let all = []; let opt = { method: 'get', url: 'all/teacher', success: res => { all = res.data.value || []; }, fail: err => { tipInfo(err.data.desc, '提示', false, 'warning'); } }; $http(opt); return all; } console.log(getAll()); // []
$http是在axios基础 进行封装的,是一个异步的方法,所以在组件中调用getAll()方法,拿到的是一个空数组
使用promise进行封装
export function getAll() { return new Promise((resolve, reject) => { let opt = { method: 'get', url: 'all/teacher', success: res => { resolve(res.data.value || []); }, fail: err => { reject(err.data.desc); } }; $http(opt); }); } // 调用 getAll() .then(data => { console.log(data); // }) .catch(err => { this.tipInfo(err.data.desc, '提示', false, 'warning'); });
使用promise进行封装后,方法,不够简洁,达不到优化的目的
使用回调函数进行封装
export function getAll(callback) { let opt = { method: 'get', url: 'all/teacher', success: res => { callback(res.data.value || []); }, fail: err => { tipInfo(err.data.desc, '提示', false, 'warning'); } }; $http(opt); } // 调用 getAllPark(data => { console.log(data); // 成功拿到数据 });
补充知识:vue多个页面用到同一个接口的数据( 比如名称列表 ),使用 vuex
第一种: 调接口不传参数
1、在 store文件夹下的 modules文件夹下新建 getName.js
// getName.js import { getNameList } from "@/apis/apis"; // 导入接口 export default { state: { nameList: [] // 名称列表 }, mutations: { changeNameList(state, payload) { state.nameList= payload; } }, actions: { geName(context) { getNameList ({}).then(res => { if (res.code == 0) { context.commit("changeNameList", res.data); } else { Message.error(res.message); } }); } } };
2、在 store文件夹下 index.js 中引入 getName.js
import getNamefrom "./modules/getName"; export default new Vuex.Store({ modules: { getName }, });
3、在整个项目刚开始加载的时候就是用 dispatch 分发,这样就不管在哪个页面需要使用到都可以使用
比如打开页面首页的时候,在mounted里面就 dispatch 触发geName函数
<script> export default { mounted() { this.$store.dispatch('geName') }, }
4、如在多个页面都需要使用 nameList , 以在某一个页面使用为例,其余页面一样用法
<template> <div> <el-select v-model="form.name" placeholder="请选择名称" clearable> <el-option v-for="item in nameList" :key="item.id" :label="item.fieldName" :value="item.fieldName"></el-option> </el-select> </div> </template> <script> export default { computed: { nameList() { return this.$store.state.getName.nameList } }, } </script>
第二种: 调接口传参数
import movieService from '../services/movieService.js' export default { namespaced: true, state: { current: 1, pageSize: 2, total: 0, datas: [], isLoading: false }, mutations: { //改变状态的通用方法 设置整个状态 setState(state, newState) { for (const prop in newState) { state[prop] = newState[prop] } } }, actions: { fetch(context) { // 根据当前的分页设置,获取电影 context.commit("setState", { isLoading: true }) movieService.getMovies(context.state.current, context.state.pageSize).then(resp => { console.log(resp) context.commit("setState", resp) context.commit("setState", { isLoading: false }) }) } } }
// 在 movieService.js export default { async getMovies(page, pageSize) { const datas = await fetch("https://api.myjson.com/bins/15f8x1") .then(resp => resp.json()) return { total: datas.length, datas: datas.slice((page - 1) * pageSize, page * pageSize) //返回分页的电影数据 } }, //通过id获取电影数据 async getMovie(id) { const datas = await fetch("https://api.myjson.com/bins/15f8x1") .then(resp => resp.json()) return datas.find(item => item._id === id) } }
在页面使用:
mounted() { //远程获取数据 this.$store.dispatch("movie/fetch") //出发vuex中movie.js里的action,获取数据 },
以上这篇vue之封装多个组件调用同一接口的案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
标签:
vue,封装,组件,调用接口
极乐门资源网 Design By www.ioogu.com
极乐门资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com
暂无vue之封装多个组件调用同一接口的案例的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 秀兰玛雅.1999-友情人【大旗】【WAV+CUE】
- 小米.2020-我想在城市里当一个乡下人【滚石】【FLAC分轨】
- 齐豫.2003-THE.UNHEARD.OF.CHYI.3CD【苏活音乐】【WAV+CUE】
- 黄乙玲1986-讲什么山盟海誓[日本东芝版][WAV+CUE]
- 曾庆瑜1991-柔情陷阱[台湾派森东芝版][WAV+CUE]
- 陈建江《享受男声》DTS-ES6.1【WAV】
- 群星《闪光的夏天 第5期》[FLAC/分轨][392.38MB]
- 徐小凤《三洋母带》1:1母盘直刻[WAV+CUE][981M]
- 王菲1995《菲靡靡之音》[香港首版][WAV+CUE][1G]
- 《双城之战》主题小游戏现已上线 扮演金克丝探索秘密基地
- 《霍格沃茨之遗》PS5Pro画面对比:光追性能显著提升
- 《怪猎荒野》PS5Pro主机版对比:B测性能都不稳定
- 黄宝欣.1992-黄宝欣金装精选2CD【HOMERUN】【WAV+CUE】
- 群星.1996-宝丽金流行爆弹精丫宝丽金】【WAV+CUE】
- 杜德伟.2005-独领风骚新歌精选辑3CD【滚石】【WAV+CUE】