uni-app接口请求封装
首先根目录下新建文件夹取名随意,这里我取名common(意为:常见的、共有的)
然后新建request.js文件,贴入以下代码
-
let server_url = ''; //请求根路径(服务器地址)
-
let token = '';//token令牌
-
// process.env.NODE_ENV === 'development' ? 'http://192.168**:6002' : 'http://***/api'; //环境配置,一般这个地址是需要创建一个单独的配置文件向外暴露变量的,因为有时上传文件也需要用到
-
//向外暴露一个方法,传入一个默认值(空对象)
-
export function service(options = {}) {
-
uni.getStorageSync('token') &&(token = uni.getStorageSync('token'));//从本地缓存中获取token
-
options.url = `${server_url}${options.url}`;//前面为你的服务器地址,后面为具体接口地址
-
//配置请求头
-
options.header = {
-
// 'content-type': 'application/json',//默认请求头,可不写
-
'Authorization': `${token}` //Bearer ,你请求数据需要的自定义请求头(令牌)
-
};
-
// 创建promise,因为接口请求无非就两种情况,成功或失败,成功就.then处理,失败就可以统一处理(弹框提示等等)
-
return new Promise((resolved, rejected) => {
-
//成功
-
options.success = (res) => {
-
if (Number(res.data.code) == 200) { //请求成功
-
resolved(res.data);//请求成功时返回接口数据
-
} else {
-
uni.showToast({
-
icon: 'none',
-
duration: 3000,
-
title: `${res.data.desc}`
-
});//弹窗提示接口调用失败的信息
-
rejected(res.data.desc); //这里调用promise的rejected方法传入错误信息,这样就可以在调用的接口地方直接.catch拿到错误信息了
-
}
-
-
}
-
//错误(一般没有网络的情况下会走这里)
-
options.fail = (err) => {
-
rejected(err); //请求失败时返回错误信息
-
}
-
uni.request(options);//调用uni的api,传入配置我们的外部配置参数
-
-
});
-
}
注意事项:如果是H5端一般会有跨域问题(小程序端不存在跨域问题),具体可在项目manifest文件中配置
-
"h5": {
-
// 开发环境 server 配置
-
"devServer": {
-
"port": 8088,//端口号,这个自己随便配置,防止开发多个项目是端口号冲突,跟跨域配置没关系
-
"disableHostCheck": true,//禁用 Host 检查
-
-
// 能成功跨域的前提是:本地跑项目的端口需要与后台接口允许跨域的端口一致
-
"proxy": {
-
"/api/sys": {
-
"target": "http://192.168**:6002",//请求目标路径
-
"changeOrigin": true,//当为true时,代理服务器向后端发送请求时端口号会与后端端口号一致,vue里面默认为true,react默认为false,如果为false,向后端发送请求时后端显示的端口号就还是本地的端口号,如果后端没有做出限制还是能请求
-
"secure": false,
-
"ws": false,//用于支持websocket,默认为true
-
// "pathRewrite": {//重写本地发起的路径
-
// "^/api/sys": "/api"//正则表达式,将/api/sys变成/api,如果接口接口地址有api这个路径就变成api,如果没有就把他变成空字符串
-
// }
-
},
-
//可配置多个
-
"/api/contract": {
-
"target": "http://192.168.**:6001",//目标地址
-
"changeOrigin": true,//允许跨域
-
"secure": false,
-
"ws": false
-
}
-
}
-
}
-
}
使用:新建api.js文件(用于管理所有的api接口),如果项目比较大建议在每个模块的文件夹下都建一个api.js,或者建一个文件夹下面创建多个api.js文件
第一步:参数配置
import {service} from '../../../common/request.js'//request向外暴露的方法 export function login(data) { //传入对应的配置对象 return service({ url: '/api/sys/loginController/userLogin',//接口地址 method: 'GET',//请求方法 data//请求接口需要的参数 }) }第二步:页面调用
import {login} from './api.js'//具体根据你项目的路径修改 click() { //params为接口需要的参数 login(params).then(res => { if (res.code == 200) { //一般成功状态码都是200,根据实际情况判断 //此处为接口调用成功之后需要做的事情 } else { //否者就是不成功,一般会弹出错误信息 } }) }
uni-app接口请求封装的更多相关文章
- 微信小程序request(ajax)接口请求封装
微信小程序request(ajax)接口请求封装 最近在进行小程序的编写,需要调用后端接口,经常要用到wx.request方法,所以就自己封装了一下,简化一下代码,如果能给大家提供帮助更好,在封装的时 ...
- uni-app(二)接口请求封装,全局输出api
在项目 main.js 同级创建 utils 文件夹, utils里创建 config.js文件,存储重要参数 // 获取平台信息 const { system, } = uni.getSystemI ...
- 微信小程序HTTP接口请求封装
1.方法封装(新建文件夹util,工具文件,在文件夹下创建request.js文件,用于对方法封装)request.js: var app = getApp(); //项目URL相同部分,减轻代码量, ...
- MOOC(7)- case依赖、读取json配置文件进行多个接口请求-封装mock(9)
封装mock # -*- coding: utf-8 -*- # @Time : 2020/2/12 8:51 # @File : mock_demo_9.py # @Author: Hero Liu ...
- 《PHP开发APP接口》笔记
PHP开发APP接口 [TOC] 课程地址 imooc PHP开发APP接口 学习要点 APP接口简介 封装通信接口方法 核心技术 APP接口实例 服务器端 -> 数据库|缓存 -> 调用 ...
- 简单的基于Vue-axios请求封装
具体实现思路=>封装之前需要用npm安装并引入axios,使用一个单独的js模块作为接口请输出对象,然后export dafult 这个对象. 1.首先我们需要在Vue实例的原型prototyp ...
- angular cli http请求封装+拦截器配置+ 接口配置文件
内容:接口配置文件.http请求封装 .拦截器验证登录 1.接口配置文件 app.api.ts import { Component, OnInit } from '@angular/core'; / ...
- 【uni-app】uni.request二次封装,更好的管理api接口和使用
前言 之前写了一个Vue.js的axios二次封装(点击跳转),这次是uni-app,uni-app是基于vue.js框架的,我觉得是很好用的一个框架,而且一套代码编译那么多平台,非常节省成本,当然, ...
- python自动化--接口请求及封装
基于http协议,最常用的是GET和POST两种方法. 接口文档需要包含哪些信息: 接口名称接口功能接口地址支持格式 json/xml请求方式请求示例请求参数(是否必填.数据类型.传递参数格式)返回参 ...
- 接口请求失败处理,重新请求并限制请求次数.自己封装搞定retry函数
最近开发一款小程序的时候想到一个问题,如果接口突然挂掉怎么办呢,于是乎想到一个解决办法.接口请求重试功能.并限制请求次数 用最新的async函数语法实现.代码简洁明了. 测试代码如下: functio ...
随机推荐
- 深入理解web协议(二):DNS、WebSocket
本文首发于 vivo互联网技术 微信公众号链接:https://mp.weixin.qq.com/s/AkbAN4UZLDf841g1ZLFPBQ作者:Wu Yue 本文系统性的讲述了 DNS 协议与 ...
- ElementUI - <el-table> 表格 selection 设置的复选框禁止选中某些行
https://blog.csdn.net/weixin_44198965/article/details/119026054
- 一套前后台全部开源的H5商城送给大家
博主给大家推荐一套全部开源的H5电商项目waynboot-mall.由博主在2020年开发至今,已有三年之久.那时候网上很多的H5商城项目都是半开源版本,要么没有H5前端代码,要么需要加群咨询,属实恶 ...
- C# 通过ServiceStack 操作Redis——Hash类型的使用及示例
接着上一篇,下面转到hash类型的代码使用 Hash:结构 key-key-value,通过索引快速定位到指定元素的,可直接修改某个字段 /// <summary> /// Hash:类似 ...
- C#设计模式06——适配器的写法
什么是适配器模式? 适配器模式是一种结构型设计模式,用于将现有接口转换为符合客户端期望的接口.适配器模式允许不兼容的类可以相互协作. 为什么需要适配器模式? 在实际开发中,经常会遇到需要复用一些已有的 ...
- python常见面试题讲解(七)合并表记录
题目描述 数据表记录包含表索引和数值(int范围的整数),请对表索引相同的记录进行合并,即将相同索引的数值进行求和运算,输出按照key值升序进行输出. 输入描述: 先输入键值对的个数然后输入成对的in ...
- Linux进阶命令-grep
Linux进阶命令----grep 目录 Linux进阶命令----grep grep 命令介绍 grep命令格式 常用选项 模式部分 匹配字符: 匹配次数: 位置锚定: grep 命令介绍 Linu ...
- [转帖]Prometheus Shell Exporter
Shell Exporter can execute Powershell or Bash scripts and transform its output to Prometheus metrics ...
- [转帖]TiDB Control 使用说明
https://docs.pingcap.com/zh/tidb/stable/tidb-control TiDB Control 是 TiDB 的命令行工具,用于获取 TiDB 状态信息,多用于调试 ...
- [转帖]基于Fuse的用户态文件系统性能优化几点建议
https://zhuanlan.zhihu.com/p/68085075 目前很多文件系统基于Fuse( http://fuse.sourceforge.net/ )开发,在较为深入钻研Fuse实现 ...