推荐下我写的uni-http

  1. 创建http-config.js
import Vue from 'vue'

const BASE_URL = 'http://xxx.com';

if (process.env.NODE_ENV === 'development') {

  // #ifdef H5
Vue.prototype.apiUrl = '';
// #endif // #ifndef H5
Vue.prototype.apiUrl = BASE_URL;
// #endif } else {
Vue.prototype.apiUrl = BASE_URL;
} function setDefaultObj(options) { // default show loading icon
if (options.loading === undefined) {
options.loading = true;
} // default method is get
if (!options.method) options.method = 'GET' // send formdata 发送文件不能写
if (options.formData && !options.datafilePath) {
options.header = {
...options.header,
'Content-Type': 'application/x-www-form-urlencoded'
}
} // deault data
if (!options.data) options.data = {} // token data
if (!options.data.token) {
// options.data.token = uni.getStorageSync('token') || '';
} // params
if (options.params && Object.prototype.toString.call(options.params) === '[object Object]') {
const paramsString = _jsonToSerialize(options.params);
const s = options.url.indexOf('?') <= 0 ? '?' : '&';
options.url += s + paramsString;
}
} Vue.prototype.request = function(options) {
let _res, _rej;
let _promise = new Promise((res, rej) => {
_res = res;
_rej = rej;
}); setDefaultObj(options);
if (options.loading) {
uni.showLoading({
title: '加载中'
});
} let url = options.url;
if (!options.url.match(/^https?:\/\//)) {
url = _join(this.apiUrl, options.url);
} if (options.filePath) {
// 传文件
// https://www.kancloud.cn/guobaoguo/uni-app/821793
const uploadTask = uni.uploadFile({
url: url,
filePath: options.filePath,
name: options.name,
formData: options.data,
header: options.header,
success: res => {
if (options.loading) uni.hideLoading();
const data = JSON.parse(res.data);
if (typeof options.success == "function")
options.success(data);
_res(data);
},
fail: res => {
if (options.loading) uni.hideLoading();
const data = { ...res,
data: JSON.parse(res.data)
};
if (typeof options.fail == "function") options.fail(data);
_rej(data);
}
});
} else {
uni.request({
url: url,
data: options.data,
method: options.method,
header: options.header,
success: res => {
if (options.loading) uni.hideLoading();
if (typeof options.success == "function") options.success(res.data);
_res(res.data);
},
fail: res => {
if (options.loading) uni.hideLoading();
if (typeof options.fail == "function") options.fail(res);
_rej(res)
}
});
}
return _promise;
} Vue.prototype.postHttp = function(options) {
return this.request({
...options,
method: 'POST',
formData: options.formData === false || options.filePath ? false : true,
});
} function _join(a_url, b_url) {
return a_url.replace(/\/+$/, "") + "/" + b_url.replace(/^\/+/, "")
} function _jsonToSerialize(o) {
let s = '';
for (let k in o) {
let v = o[k];
let vTag = Object.prototype.toString.call(v);
if (vTag === '[object Array]') {
for (let i of v) {
s += `${k}=${encodeURIComponent(i)}&`
}
} else if (vTag === '[object Object]') {
s += `${k}=${encodeURIComponent(JSON.stringify(v))}&`
} else {
s += `${k}=${encodeURIComponent(v)}&`
}
}
return s.replace(/&$/, '');
} export default {
BASE_URL: BASE_URL,
apiUrl: Vue.prototype.apiUrl,
request: Vue.prototype.request.bind(Vue.prototype),
postHttp: Vue.prototype.postHttp.bind(Vue.prototype),
}
  1. main.js中导入
import './http-config';
  1. manifest.json配置代理
{
... "h5": {
"router": {
"mode": "hash"
},
"devServer": {
"https": false,
"proxy": {
"/api": {
"target": "http://xxx.com",
"changeOrigin": true,
"secure": false,
"pathRewrite": {
"^/api": "/"
}
}
}
}
} }
  1. 使用
    // http://xxx.com/getvideo
this.request({
url: '/getvideo',
success: res => {
// ...
}
});

也可以看看:

uniapp 发起网络请求的更多相关文章

  1. uni-app之网络请求

    uni-app之网络请求 一,介绍 uni.request(OBJECT),发起网络请求,以下主要是一些特殊的参数说明,详细的可查看uni-app官网. 1,method的有效值必须是大写,默认GET ...

  2. android4.0 HttpClient 以后不能在主线程发起网络请求

    android4.0以后不能在主线程发起网络请求,该异步网络请求. new Thread(new Runnable() { @Override public void run() { // TODO ...

  3. iOS swift HandyJSON组合Alamofire发起网络请求并转换成模型

    在swift开发中,发起网络请求大部分开发者应该都是使用Alamofire发起的网络请求,至于请求完成后JSON解析这一块有很多解决方案,我们今天这里使用HandyJSON来解析请求返回的数据并转化成 ...

  4. 使用axios优雅的发起网络请求

    原文链接:https://www.jianshu.com/p/73585303fdc0 公司项目使用了vue作为技术栈,便理所应当地使用了官方推荐的axios进行网络请求,这里记录下axios的封装方 ...

  5. 木马——本质就是cs socket远程控制,反弹木马是作为c端向外发起网络请求

    摘自:http://kczxsp.hnu.edu.cn/upload/20150504165623705.pdf 里面对于木马的实验过程写得非常清楚,值得一看.   木马是隐藏在正常程序中的具有特殊功 ...

  6. 小程序uni-app发起网络异步请求

    // uni.request({ // url: 'api/boxs/search', // // 使用监听函数防止this指向改变 // success: res => { // // 判断是 ...

  7. vue 如何发起网络请求 之 axios

    1   1 2 3 4 5 6 7 8 9 10 // axios 请求  在main.js里边写入 import Axios from 'axios'   // 配置请求信息 var $http = ...

  8. thinkphp发起网络请求

    常规做法使用CURL方法: private function http_request($url,$data = null,$headers=array()){ $curl = curl_init() ...

  9. uni-app 网络请求

    uni.request发起网络请求 url 开发者服务器接口地址 data 请求的参数 header method dataType responseType 设置响应的数据类型 statusCode ...

随机推荐

  1. List对象集合根据组合属性进行差集运算

    背景   当List是一个基本数据类型的集合的时候,进行集合运算还比较方便,但是有这么一些业务场景,比如某个用户权限变化的列表,或者取数据的变化结果,当时有时候用笨方法多循环两次也是可以的,只不过代码 ...

  2. Excel三个下拉互斥

    Excel三个下拉互斥 描述:Excel有三个下拉列表,若选择了其中任意一个下拉,其他两个均不可以在选择. 尝试了很多种办法,级联,数据有效性等等,最后都没实现. 老大,最后用VBA实现. 附上代码: ...

  3. Web漏洞扫描-AWVS

    Web漏洞扫描-AWVS 一.AWVS概述 二.功能以及特点 三.AWVS界面 四.AWVS使用 相关优质博文: CSDN:帽子不够白:WEB渗透测试之三大漏扫神器 一.AWVS概述 Acunetix ...

  4. Grafana+Influxdb+Telegraf监控mysql

    Grafana+Influxdb+Telegraf监控mysql 一.安装 1.1安装Grafana+influxdb+telegraf 1.2启动服务,添加开机启动 1.3查看grafana界面 二 ...

  5. 周期性清除Spark Streaming流状态的方法

    在Spark Streaming程序中,若需要使用有状态的流来统计一些累积性的指标,比如各个商品的PV.简单的代码描述如下,使用mapWithState()算子: val productPvStrea ...

  6. (Linux环境Kafka集群安装配置及常用命令

    Linux环境Kafka集群安装配置及常用命令 Kafka 消息队列内部实现原理 Kafka架构 一.下载Kafka安装包 二.Kafka安装包的解压 三.设置环境变量 四.配置kafka文件 4.1 ...

  7. F - F(最小生成树)

    题意:连通各点最短距离,最小生成树. You are assigned to design network connections between certain points in a wide a ...

  8. Educational Codeforces Round 20

    Educational Codeforces Round 20  A. Maximal Binary Matrix 直接从上到下从左到右填,注意只剩一个要填的位置的情况 view code //#pr ...

  9. c++格式化输入输出以及操纵器的使用

    C++格式化输入和输出 1,ios类中定义的格式控制标志 ios类中定义了一个数据成员:格式控制标志字,long x_flags x_flags每一位的状态值用枚举符号常量定义:如下列出常用几个 en ...

  10. c语言实现--不带头结点的单链表操作

    1,不带头结点的单链表操作中,除了InitList(),GetElem(),ListInsert(),ListDelete()操作与带头结点的单链表有差别外,其它的操作基本上一样. 2,不带头结点单链 ...