UniApp 封装全局请求示例并配置拦截器以及错误回调指南

✨求关注~
😀博客:www.protaos.com

本文将介绍如何在 UniApp 中封装全局请求示例,并配置请求拦截器和错误回调函数,以>便统一处理网络请求、添加请求头、处理错误等功能。通过本指南,你将学习如何优化请>求流程并提高代码的可维护性。

代码实现:

  1. 首先,确保你已经创建了一个 UniApp 项目。

  2. 在项目的根目录下创建一个新文件夹 api,然后在该文件夹中创建 request.js 文件,作为请求封装的入口文件。

  3. request.js 文件中,编写请求封装的代码:

import { BASE_URL } from './config'; // 导入请求的基础 URL

// 封装请求方法
function request(url, method, data) {
  return new Promise((resolve, reject) => {
    uni.request({
      url: BASE_URL + url,
      method: method,
      data: data,
      header: {
        'Content-Type': 'application/json', // 设置请求头
      },
      success: (res) => {
        if (res.statusCode === 200) {
          resolve(res.data);
        } else {
          reject(res);
        }
      },
      fail: (err) => {
        reject(err);
      },
    });
  });
}

// 配置请求拦截器
uni.addInterceptor('request', {
  // 在发送请求之前做一些处理
  config(requestConfig) {
    // 添加请求头、身份验证等
    requestConfig.header.Authorization = 'Bearer ' + uni.getStorageSync('token');
    return requestConfig;
  },
  // 请求发生错误时的处理
  fail(error) {
    console.error('请求失败:', error);
  },
});

export default request;
  1. 在需要发起网络请求的页面或组件中引入 request.js 并使用封装的 request 方法:
import request from '@/api/request.js';

// 发起请求示例
request('/api/user', 'GET', {})
  .then((res) => {
    console.log('请求成功:', res);
  })
  .catch((err) => {
    console.error('请求失败:', err);
  });

推荐学习文档或官方教程:

  1. UniApp 官方文档:https://uniapp.dcloud.io/
  2. uni.request API 文档:https://uniapp.dcloud.io/api/request/request

总结:

通过按照上述步骤,在 UniApp 中封装全局请求示例并配置拦截器和错误回调函数非常简单。首先,创建一个请求封装的入口文件,并在其中编写请求封装的代码,设置请求头、处理请求结果等。然后,在需要发起网络请求的页面或组件中引入封装的请求方法,并进行相应的调用。UniApp 的官方文档和 uni.request API 文档是学习和深入了解更多关于 UniApp 请求和

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Uniapp提供了一个全局请求拦截器和响应拦截器来对网络请求进行处理。 首先,你需要在uniapp项目的根目录下创建一个`common`文件夹,在该文件夹下创建一个`http.js`文件(可以根据自己的需求选择其他名字),用于配置拦截器。 在`http.js`文件中,你可以使用`uni.request`来发送网络请求,并通过设置拦截器来处理请求和响应。 以下是一个示例代码: ```javascript import Vue from 'vue' import App from './App' Vue.config.productionTip = false App.mpType = 'app' // 请求拦截器 uni.request.interceptor.request = (options) => { // 在请求头中添加token等信息 options.header['Authorization'] = 'Bearer ' + uni.getStorageSync('token') // 返回处理后的请求参数 return options } // 响应拦截器 uni.request.interceptor.response = (response) => { // 处理响应数据,可以根据状态码进行判断 if (response.statusCode === 200) { return response.data } else { // 错误处理 console.error('请求出错', response) return Promise.reject(response) } } const app = new Vue({ ...App }) app.$mount() ``` 在上述代码中,我们通过`uni.request.interceptor.request`来设置请求拦截器,可以在请求头中添加一些信息。通过`uni.request.interceptor.response`来设置响应拦截器,对返回的数据进行处理。 需要注意的是,在请求拦截器和响应拦截器中,我们需要返回处理后的数据,否则请求将会被中断。 以上就是uniapp中设置请求拦截器和响应拦截器的方法,你可以根据自己的需求进行定制化处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

曲江涛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值