uni-app中封装统一请求函数
封装统一请求函数有利于项目的维护
整体功能简单实用,但小编遇到一个巨坑,项目中在vue文件使用跳转方法,url参数输入 "/" 后工具提示的路径为 "/pages/login/login",
但是在外部js文件中使用uni跳转的api,快捷提示的路径为 "/pages/login/login.vue" , 这就导致实际使用找不到了,类似的情况要注意一下。
参考如下:在common文件夹下面建立一个util.js,内容如下
import {getHttpUrl} from "common/server.js"
const domain = getHttpUrl() + "/api/instructor.php/"
const req = function(a){
//console.log(a.url);
a = a || {};
var b = {
url: domain + (a.url || ""),
method: a.method || "POST",
dataType: a.dataType || "json",
header: a.header || {},
data: a.data || {},
timeout: a.timeout || 30000,
success: a.success || undefined,
fail: a.fail || undefined,
complete: a.complete || undefined,
toLogin:a.toLogin || "no"
};
if(a.loading){
uni.showLoading({
title:a.loadingTitle || "加载中",
mask: a.loadingMask || true
})
}
uni.request({
url:b.url,
method:b.method,
data:b.data,
header:b.header,
dataType:b.dataType,
timeout:b.timeout,
success:function(res){
if(res.statusCode != 200){
uni.showModal({
title:"提示",
content:"服务器繁忙,请稍后再试",
confirmColor:"#009714",
showCancel:false
})
return;
}
//console.log(res);
if(res.data.code == 0){
//console.log(res.data);
if(b.success){
b.success(res)
}
}else{
if(res.data.code == "-1" && res.data.msg == "未登录"){
if(b.toLogin == "yes"){
setTimeout(function(){
uni.redirectTo({
url:"/pages/login/login"
})
},1000)
}else{
try{
uni.removeStorageSync("userInfo");
}catch(e){
//TODO handle the exception
}
uni.showModal({
title:"提示",
content:"您未登录,请登录后再试",
showCancel:false,
confirmText:"去登陆",
confirmColor:"#FF0000",
success(e) {
if(e.confirm){
uni.redirectTo({
url:"/pages/login/login"
})
}
}
})
}
return;
}
var tipMsg = res.data.msg ? res.data.msg : "暂无数据";
setTimeout(function(){
uni.showToast({
title:tipMsg,
icon:"none",
mask:true,
duration:1500
})
},200)
}
},fail:function(err){
if(b.fail){
b.fail(err);
}else{
uni.showModal({
title:"提示",
content:"服务器繁忙,请稍后再试",
confirmColor:"#009714",
showCancel:false
})
}
},complete:function(com){
//关闭加载提示
if(a.loading){
uni.hideLoading();
}
if(b.complete){
b.complete(com);
}
}
})
}
module.exports = {
req:req
}
使用方法:
1、在要使用的vue页面中引入
2、注册到全局vue方法
import util from 'common/util.js' //统一接口请求函数
Vue.prototype.req = util.req;
uni-app中封装统一请求函数的更多相关文章
- main.js中封装全局登录函数
1. 在 main.js 中封装全局登录函数 通过 vue 对象的原型扩展,可以扩展一个函数,这样这个函数就可以在每一个界面通过类似指向对象的方式,去访问这个函数. 如下是 main.js 扩展的函数 ...
- uni app中使用自定义图标库
项目中难免会用到自定义图标,那在uni app中应该怎么使用呢? 首先, 将图标目录放在static资源目录下: 在main.js中引入就可以全局使用了 import '@/static/icon-o ...
- Ajax_04之jQuery中封装的Ajax函数
1.PHP中json_encode编码规则: PHP索引数组编码为JSON:[...] PHP关联数组编码为JSON:{...}2.jQuery中AJAX封装函数之load: ①使用:$('选择器') ...
- Mac使用Charles抓取ios手机APP中的https请求
1.配置Http代理 Port为监听端口号,默认为8888,勾选Enable transparent HTTP proxying,接着勾选SOCKS proxy,可以监听Socks请求 2.安装Cha ...
- php中封装的curl函数(抓取数据)
介绍一个封闭好的函数,封闭了curl函数的常用步骤,方便抓取数据. 代码如下: <?php /** * 封闭好的 curl函数 * 用途:抓取数据 * edit by www.jbxue.com ...
- ios中封装网络请求类
#import "JSNetWork.h" //asiHttpRequest #import "ASIFormDataRequest.h" //xml 的解析 ...
- uni app中关于图片的分包加载
因为在项目中使用了大量的静态资源图片,使得主包体积过大, 而把这些图片全部放到服务器又有点麻烦,就想能不能把图片也分包,但是直接放在分包下的话导致图片资源找不到了, 在社区中看到大佬分享的十分有用,特 ...
- vue2整个项目中,数据请求显示loading图
一般项目中,有时候会要求,你在数据请求的时候显示一张gif图片,然后数据加载完后,消失.这个,一般只需要在封装的axios中写入js事件即可.当然,我们首先需要在app.vue中,加入此图片.如下: ...
- vue2整个项目中,数据请求显示loading图----------未完成阅读,码
一般项目中,有时候会要求,你在数据请求的时候显示一张gif图片,然后数据加载完后,消失.这个,一般只需要在封装的axios中写入js事件即可.当然,我们首先需要在app.vue中,加入此图片.如下: ...
随机推荐
- WPF窗体中嵌入/使用WinForm类/控件(基于.NET Core)
如题,WPF中嵌入WinForm的做法,网络上已经很多示例,都是基于.NET XXX版的. 今天King様在尝试WPF(基于.NET Core 3.1)中加入Windows.Forms.ColorDi ...
- 为什么你写的拦截器注入不了 Java bean?
一.如何实现拦截器 在Spring Boot项目中,拦截器经常被用来做登陆验证,日志记录等操作.拦截器是Spring提供的,所以可以将拦截器注成bean,由IOC容器来管理.实现拦截器的方式很简单,主 ...
- 【鸿蒙开发板试用报告】用OLED板实现FlappyBird小游戏(上)
总是做各种Demo,是时候做个什么小应用来练练手了.踌躇了很久,果然还是搞个小游戏才有意思.想到几年前风靡全球的FlappyBird,一个屏幕一个按钮就足够了,正好适合.OLED屏幕.按键的驱动已经有 ...
- Apache Flink Dashboard未授权访问导致任意Jar包上传漏洞
漏洞危害 攻击者无需Flink Dashboard认证,通过上传恶意jar包 csdn-[漏洞复现]Apache Flink任意Jar包上传导致远程代码执行 freebuf-Apache Flink ...
- FL Studio通道乐器设置页详讲
上一篇文章我们说到FL Studio通道乐器设置页每个标签页面中几乎都是由包络.低频振荡器和滤波器这三个部分组成.我们之前只对包络进行的简单的介绍,相信很多同学对它还有其他两个的功能的了解还是云里雾里 ...
- 「CSP-S 2019」划分
description loj 3212 solution 首先容易想到\(n^3\)DP,即令\(f_{i,j}\)表示前\(i\)个数的划分,其中最后一段是从\(j\)开始时的答案 于是有 \[f ...
- Dapr DotNet5 HTTP 调用
Dapr DotNet5 HTTP 调用 版本介绍 Dotnet 版本:5.0.100 Dapr dotnet 版本:0.12.0-preview01 注意: Asp.Net Core 项目中的 la ...
- Matlab 数组
数组创建 1:逐个元素输入法:如:x=[1 2 3 4 5](中间也可以用逗号隔开) 2:冒号法:如:x=1:1:5 %从1到5步长为1 3:linspace 法: ----创建线性等距的数组 lin ...
- Java基础教程——Math类
Math Java这种级别的编程语言怎么可能没有数学相关的操作呢? java.lang.Math类提供了基本数学运算的方法. 该类是final的,说明不能被继承. 该类的构造方法是私有的(privat ...
- Java基础教程——多态
直观地说,多态就是"一个对象,多种形态 ".比如观世音菩萨就有多种形态-- 每个人都有多种形态-- 具体地讲,多态是指"同一个对象.同一个方法(函数),表现出不同的行为& ...