当前位置: 首页 > news >正文

uniapp+vue3+ts请求接口封装

1.安装luch-request

yarn add luch-request
npm install luch-request

2.新建文件src/utils/request.ts
需要自己修改config.baseURL和token(获取存储的token)

// 
import HttpRequest from 'luch-request';
import type { HttpRequestConfig, HttpResponse, HttpError, HttpTask } from "luch-request";
// * 请求响应参数(包含data)
export interface Result {code: numbermessage: stringsuccess?: boolean
}
export interface ResultData<T = any> extends Result {data: T
}
export const ResultEnum = {SUCCESS: 200,EXPIRE: [305, 601, 602],ERROR: -1,ERRMESSAGE: '请求失败',TIMEOUT: 25000,TYPE: 'success'
} as const// 创建 HTTP 请求实例
const request = new HttpRequest();
// 全局配置
request.setConfig((config) => {/* config 为默认全局配置*/// config.baseURL = 'https://www.example.com' /* 根域名 */// 判断环境设置不同的baseURLconfig.timeout = ResultEnum.TIMEOUTconfig.baseURL = "https://...../"//import.meta.env.VITE_APP_NODE_ENV === 'development' ? import.meta.env.VITE_APP_BASE_API : import.meta.env.VITE_APP_BASE_URLreturn config
})
// 请求拦截器
request.interceptors.request.use((config) => {// 在发送请求之前做些什么,比如添加 tokenconst token = uni.getStorageSync("accessToken"); // 获取你的 tokenif (token) {config.header = { ...config.header, Authorization: `Bearer ${token}` };}return config;},(error) => {// 对请求错误做些什么return Promise.reject(error);}
);// 响应拦截器
request.interceptors.response.use((response) => {// 对响应数据做点什么// 可以根据状态码进行全局错误处理if (response.statusCode === 200) {return response.data;} else {const status = response?.statusCode// 处理 HTTP 网络错误let message = ''if (status === 401) {uni.removeStorage({key: 'accessToken',success: function (res) {uni.showModal({title: "提示",content: "身份已过期,将跳转登录!",showCancel: false,success: (res) => {if (res.confirm) {uni.navigateTo({url: '/pages/login/login'})}}});},})} else {switch (status) {case 403:message = '拒绝访问'breakcase 404:message = '请求地址错误'breakcase 500:message = '服务器故障'breakdefault:message = '网络连接故障'}uni.showToast({title: message,icon: 'error'})}return Promise.reject(response);}},(error) => {// 对响应错误做点什么const status = error?.statusCode// 处理 HTTP 网络错误let message = ''if (status === 401) {uni.removeStorage({key: 'accessToken',success: function (res) {uni.showModal({title: "提示",content: "身份认证失败,将跳转登录!",showCancel: false,success: (res) => {if (res.confirm) {uni.navigateTo({url: '/pages/login/login'})}}});},})} else {switch (status) {case 403:message = '拒绝访问'breakcase 404:message = '请求地址错误'breakcase 500:message = '服务器故障'breakdefault:message = '网络连接故障'}uni.showToast({title: message,icon: 'error'})}return Promise.reject(error);}
);
const http = {get<T>(url: string, params?: object, config?: HttpRequestConfig): Promise<ResultData<T>> {return request.get(url, { params, ...config })},post<T>(url: string, data?: object, config?: HttpRequestConfig): Promise<ResultData<T>> {return request.post(url, data, config)},put<T>(url: string, data?: object, config?: HttpRequestConfig): Promise<ResultData<T>> {return request.put(url, data, config)},delete<T>(url: string, data?: object, config?: HttpRequestConfig): Promise<ResultData<T>> {return request.delete(url, data, config)}
}
export default http;

3.使用

import http from '@/utils/request'try {const response = await http.get("接口名",{ id: 11409 });console.log(response,'测试:1.需要身份验证token,2.不需要身份验证,3.带参数请求接口')} catch (error) {console.error('Failed to fetch data:', error);}
http://www.lryc.cn/news/497695.html

相关文章:

  • 【计算机网络】实验4:生成树协议STP的功能以及虚拟局域网VLAN
  • 基于Matlab BP神经网络的电力负荷预测模型研究与实现
  • java 21 多线程
  • Rust学习笔记_07——枚举和范围
  • 40分钟学 Go 语言高并发:服务性能调优实战
  • Windows通过指令查看已安装的驱动
  • Windows 11 如何配置node.js
  • AWTK fscript 中的 串口 扩展函数
  • yolov11剪枝
  • 智慧地图聚合(LockMap)标注系统开发说明文档
  • 「Mac畅玩鸿蒙与硬件36」UI互动应用篇13 - 数字滚动抽奖器
  • cuda12.1版本的pytorch环境安装记录,并添加到jupyter和pycharm中
  • Linux: network: nic: mellanox MRU初现
  • 深入理解红黑树的底层逻辑
  • 【数据结构】手搓链表
  • ThinkPHP场景动态验证
  • 在M3上面搭建一套lnmp环境
  • 【C++笔记】二叉搜索树
  • Fork/Join框架简介
  • Java项目实战II基于微信小程序的电子竞技信息交流平台的设计与实现(开发文档+数据库+源码)
  • Mysql读写分离分库分表
  • B站狂神说--springboot项目学习(新建一个springboot项目)
  • eltable el-table 横向 滚动条常显
  • centos8 mysql 主从复制
  • 【C++】入门【五】
  • 【React】二、状态变量useState
  • SQL Server中的数据处理函数:提升SQL查询能力
  • TypeScript 语言学习入门级教程五
  • 上海市计算机学会竞赛平台2022年7月月赛丙组匹配括号(三)
  • 108.【C语言】数据结构之二叉树查找值为x的节点