小程序中封装api请求
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小程序中封装api请求相关的知识,希望对你有一定的参考价值。
参考技术A 一、在pages同级创建request文件夹 在此文件夹下创建一个index.js文件夹 在此文件夹内写入封装的apiconst request = (method,url,params) => // method (请求方式) url (请求的路径) params (请求的参数)
return new Promise((resolve,reject) => // 创建一个promise函数
let baseUrl = "公共url"
uni.showLoading( // 添加加载动画
title: '加载中'
);
uni.request( // 发送请求
url: baseUrl + url, // url 形参就是传入的地址
data: params? params:'', // 传入的请求参数
method: method, // 传入的请求方式
success: res => // 成功的函数
resolve(res.data);
uni.hideLoading();
,
fail: err => // 失败的函数
reject(err);
uni.hideLoading();
);
)
const api =
get: (url,params) => request("GET",url,params),
post: (url,params) => request("POST",url,params)
export default api; // 抛出接口
二、在request 文件目录下 创建一个 home文件夹 在home 文件夹内新建index.js文件
// 所有的首页的请求 ,都放在这里维护
import api from '../index.js';
export const get = params => api.get('路径',params); // get请求
export const post = params => api.post('路径',params); // post请求
三、在所需要请求数据的页面内
import 请求名 from '文件路径';
promise封装小程序api请求
在项目中我们使用请求 需要通过api封装
- 为什么封装api
因为在项目中 请求使用的地方会有很多 不利于后期维护 如果我我们讲api封装出来 只需要维护api文件就可以了
这里以uniapp封装api来写小程序为例
第一步
- 先在项目目录中创建一个utils文件夹 在该文件夹下创建一个js文件为请求的封装 代码如下
// 封装请求
const http = (url, method='get', data='') =>
return new Promise((resolve, reject) =>
uni.request(
method,
url: `公共请求地址` + url,
data,
success(res)
resolve(res.data) // 将请求成功后得到的数据返回出去 可以用then方法接受到数据
,
fail(err)
reject(err) // 将请求失败后返回的信息 返回出去 可以用catch方法接受到
,
complete()
)
)
export default http;
第二步
- 在utils文件夹下创建一个api.js 这里以请求轮播图数据的接口为例
import http from './http.js'
// 请求轮播图数据的接口
export const getSwiper = () => http(url: '你们自己的请求轮播图数据的接口地址')
第三步
- 在需要使用轮播图接口的文件中
import getSwiper from '../../utils/api.js'
export default
data()
return
swiper: []
,
async created()
let message = await getSwiper() // message就是我们请求完成后获取的数据信息
this.swiper = message
,
以上是关于小程序中封装api请求的主要内容,如果未能解决你的问题,请参考以下文章