全栈的自我修养 ———— uniapp中封装api请求

文章介绍了如何在uni-app项目中封装API请求函数,包括登录功能和通用的请求处理,以及如何根据开发或生产环境切换URL。使用了`uni.request`和Promise实现异步请求,并提供了加载提示和错误处理机制。
摘要由CSDN通过智能技术生成

api

import request from '@/tools/request'
export function login(loginMessage) {
    return request({
        url: '/login',
        data: loginMessage,
        loading: true
    })
}

request

// request
const urlArr = {
    'DEV': 'http://localhost:6060', // 开发
    'PRO': 'https://域名:6060', // 生产
}

let BASEURL = urlArr['DEV'] // 调整当前环境

export default item => {
    if (item.loading) {
        uni.showLoading({
            title: "加载中",
            mask: true
        });
    }
    return new Promise((resolve, reject) => {
        uni.request({
            url: BASEURL + item.url,
            method: item.method ? item.method : 'post',
            data: item.data,
            headers: item.headers ? item.headers : { "Content-Type": "application/json" },
            timeout: 20000,
            success(response) {
                resolve(response.data);
            },
            fail(err) {
                uni.showToast({
                    icon: "none",
                    title: '服务响应失败'
                });
                reject(err);
            },
            complete() {
                uni.hideLoading();
            }
        });
    })
};

使用

import { login,sendCaptcha } from '@/api/login.js'
const res = await login(params)
uniapp封装请求API的方法可以参考以下步骤: 1. 首先,在项目新建一个http.js文件,可以放在api文件夹下。在该文件,可以导入接口的前缀地址,例如baseURL。然后,定义一个myRequest方法,该方法接收一个options参数,并返回一个Promise对象。在该方法,可以使用uni.request方法发送请求,设置请求的url、method、data、header等参数。在请求成功时,可以关闭Loading,判断返回的数据是否符合预期,如果不符合则使用uni.showToast方法提示获取数据失败,如果符合则使用resolve方法返回数据。在请求失败时,可以使用reject方法返回错误信息。最后,记得在请求开始时显示Loading,请求结束时隐藏Loading。[1] 2. 接下来,在http文件夹下新建一个request.js文件。在该文件,可以定义一个全局请求封装方法。首先,设置请求的基础地址,例如base_url。然后,根据请求方法或URL来判断是否添加请求头,例如根据method是否为"post"来设置header的token和content-type。接着,使用uni.request方法发送请求,设置请求的url、method、header、data等参数。在请求成功时,根据返回的状态码进行相应的操作,例如判断Errcode是否为'0',如果是则使用resolve方法返回数据,如果不是则使用uni.clearStorageSync方法清除本地缓存,并使用uni.showToast方法提示获取失败,并跳转到登录页面。在请求失败时,使用reject方法返回错误信息。最后,记得在请求开始时显示Loading,请求结束时隐藏Loading。[2] 3. 最后,在main.js文件,可以将封装请求API导入并挂载到Vue的原型上,以便在页面使用。首先,导入封装请求API,例如api。然后,使用Vue.prototype将api挂载到Vue的原型上,这样在页面就可以通过this.api来调用封装请求方法。[3] 通过以上步骤,你就可以在uniapp封装请求API,并在页面使用了。在页面,可以通过调用this.api的方法来发送请求,例如this.api.GetSceneData()。[1][2][3]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值