uniapp封装请求

在uniapp中封装HTTP请求,通常我们会使用uni.request方法。uni.request是uni-app提供的一个网络请求API,可以用来发送各种类型的HTTP请求(GET、POST、PUT、DELETE等)。下面是如何在uniapp中封装一个通用的HTTP请求方法,以便于在项目的各个部分复用。

1. 创建请求方法

首先,你可以在项目的utils目录下创建一个http.js文件,用于封装HTTP请求。

复制代码
// utils/http.js
 
import store from '@/store' // 如果使用Vuex,引入store
 
const baseUrl = 'https://你的接口域名'; // 你的接口基础URL
 
function request(options) {
    const { url, method = 'GET', data = {}, headers = {} } = options;
    return new Promise((resolve, reject) => {
        uni.request({
            url: baseUrl + url,
            method,
            data,
            header: {
                ...headers,
                'content-type': 'application/json' // 根据需要设置内容类型
            },
            success: (res) => {
                if (res.statusCode === 200) {
                    resolve(res.data); // 成功时返回数据
                } else {
                    reject(res); // 失败时返回错误信息
                }
            },
            fail: (error) => {
                reject(error); // 请求失败时返回错误信息
            }
        });
    });
}
 
export default request;

2. 使用拦截器(可选)

为了增强请求的灵活性,比如添加统一的请求头、处理登录状态、错误提示等,你可以添加请求拦截器和响应拦截器。例如:

复制代码
// utils/http.js (修改后的版本)
import store from '@/store'; // 引入store,如果使用Vuex的话
 
const baseUrl = 'https://你的接口域名'; // 你的接口基础URL
const tokenKey = 'your_token_key'; // 假设token存储在这个key中,根据实际情况修改
 
function request(options) {
    const { url, method = 'GET', data = {}, headers = {} } = options;
    const token = uni.getStorageSync(tokenKey); // 获取token,根据实际情况调整获取方式
    const defaultHeaders = {
        'Authorization': token ? `Bearer ${token}` : '', // 如果存在token,则添加到请求头中
        'content-type': 'application/json' // 根据需要设置内容类型
    };
    return new Promise((resolve, reject) => {
        uni.request({
            url: baseUrl + url,
            method,
            data,
            header: { ...defaultHeaders, ...headers }, // 使用展开运算符合并默认头和自定义头
            success: (res) => {
                if (res.statusCode === 200) {
                    resolve(res.data); // 成功时返回数据
                } else if (res.statusCode === 401) { // 例如,处理401未授权错误,可能需要重新登录等操作
                    // 可以根据实际情况处理,例如跳转到登录页面等
                    reject(new Error('Unauthorized')); // 或者其他错误处理逻辑
                } else {
                    reject(res); // 其他错误情况返回错误信息
                }
            },
            fail: (error) => {
                reject(error); // 请求失败时返回错误信息
            }
        });
    });
}

3. 在项目中调用封装的方法

现在你可以在项目的其他部分通过引入http.js来使用封装的request方法了。例如:

复制代码
import request from '@/utils/http'; // 引入封装的方法
 
export default {
    methods: {
        fetchData() {
            request({ url: '/api/data', method: 'GET' })
                .then(data => {
                    console.log(data); // 处理返回的数据
                })
                .catch(error => {
                    console.error(error); // 处理错误情况
                });
        }
    }
}

这样,你就可以在uniapp中方便地使用封装好的HTTP请求方法了。

相关推荐
码农客栈5 小时前
小程序学习(十一)之uni-app和原生小程序开发区别
学习·小程序·uni-app
Json____6 小时前
使用uni-app开发抖音小程序遇到previewImage方法图片加载不出来解决方案
小程序·uni-app
Jyywww1217 小时前
Uniapp+Vue3 使用父传子方法实现自定义tabBar
javascript·vue.js·uni-app
2501_916008891 天前
iOS开发APP上架全流程解析:从开发到App Store的完整指南
android·ios·小程序·https·uni-app·iphone·webview
酷酷的鱼1 天前
2026 跨平台开发终极选型:Flutter, React Native 与 uni-app x 深度博标与规划指南
flutter·react native·uni-app
biyezuopinvip1 天前
基于uni-app和Express的问答对战小程序的设计与实现(论文)
小程序·uni-app·毕业设计·论文·express·毕业论文·问答对战小程序的设计与实现
2501_915909062 天前
Charles 抓不到包怎么办?iOS 调试过程中如何判断请求路径
android·ios·小程序·https·uni-app·iphone·webview
2501_916007472 天前
iOS和iPadOS文件管理系统全面解析与使用指南
android·ios·小程序·https·uni-app·iphone·webview
卜锦元2 天前
EchoChat搭建自己的音视频会议系统01-准备工作
c++·golang·uni-app·node.js·音视频
敲敲了个代码2 天前
让 Vant 弹出层适配 Uniapp Webview 返回键
前端·javascript·vue.js·学习·面试·uni-app