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

api

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

request

js 复制代码
// 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();
            }
        });
    })
};

使用

js 复制代码
import { login,sendCaptcha } from '@/api/login.js'
const res = await login(params)
相关推荐
2301_815279528 分钟前
实战分享实现 C++ 管理类单例模式:特点与最佳实践
javascript·c++·单例模式
原则猫17 分钟前
await 到底在等待什么
前端
西洼工作室26 分钟前
fetch+ReadableStream实现SSE推送实时踢人下线
前端·python·全栈
2401_8784545327 分钟前
js的复习(一)
开发语言·javascript·ecmascript
农夫山泉不太甜32 分钟前
Nuxt 4 完全指南:从入门到精通
前端
Momo__34 分钟前
Vue 3.4+ 被低估的 3 个 API,让你的代码更优雅
前端·vue.js
dishugj37 分钟前
HANA数据库常用命令总结
java·前端·数据库
clove41 分钟前
JavaScript 提升(Hoisting)与声明优先级:一篇文章说透
前端
七牛开发者1 小时前
不写框架、不用 npm,我用 AI Coding 做了一个家庭记忆站
前端·人工智能·npm