• 在项目 main.js 同级创建 utils 文件夹,
  • utils里创建 config.js文件,存储重要参数
    //  获取平台信息
    const {
    system,
    } = uni.getSystemInfoSync() // 请求服务器环境,xxx 在这里是填充,请自行替换
    let baseUrl = ['http://xxx', 'https://xxx'] // 小程序重要参数
    uni.config = {
    platform: system.startsWith("iOS") ? 2 : 1, // IOS为2 安卓为1
    imgUrl: "https://xxx", // 图片地址前缀
    baseUrl: baseUrl[1],
    appid: "xxx", // appid
    }
  • utils里创建request.js文件,封装接口请求
    // 登录接口域名
    const LOGIN_URL = '/xx/xx'
    const {
    baseUrl,
    appid
    } = uni.config // 封装接口请求
    uni.http = (args = {}) => {
    let url = args.url || ''
    let data = args.data || {}
    data.appid = appid
    let method = args.method || 'GET'
    return new Promise((resolve, reject) => {
    request(url, data, method, resolve, reject)
    })
    } // 接口封装
    const request = async (url, data = {}, method, resolve, reject) => {
    let token = await getToken()
    let header = {
    'content-type': 'application/x-www-form-urlencoded',
    'token': token
    }
    uni.request({
    header,
    url: baseUrl + url,
    method,
    data,
    dataType: 'json',
    success: res => {
    if (res.statusCode == 200) {
    let code = res.data.return
    if (code == 0) {
    resolve(res.data)
    } else {
    uni.showModal({
    title: '错误码:' + code,
    content: res.data.result
    })
    }
    }
    },
    fail: err => {
    reject(err)
    }
    })
    } // 获取Token
    const getToken = async () => {
    let token = uni.getStorageSync('token')
    if (token) {
    return token
    } else {
    let tokenRes = await login()
    return tokenRes.data.token
    }
    } // 封装登录
    const login = () => {
    return new Promise((resolve, reject) => {
    uni.getProvider({
    service: "oauth",
    success(providerRes) {
    let provider = providerRes.provider[0]
    uni.login({
    provider,
    success: (codeRes) => {
    uni.request({
    url: baseUrl + LOGIN_URL,
    method: 'POST',
    header: {
    'content-type': 'application/x-www-form-urlencoded',
    appid
    },
    data: {
    code: codeRes.code
    },
    dataType: 'json',
    success: (res) => {
    if (res && res.statusCode == 200) {
    // 存储用户信息
    uni.setStorageSync('status', res.data.data)
    // 存储用户token
    uni.setStorageSync('token', res.data.token)
    resolve(res.data)
    } else {
    reject(res)
    }
    },
    fail: (err) => {
    reject(err)
    }
    })
    },
    fail: (err) => {
    reject(err)
    }
    })
    }
    })
    })
    }
  • utils里创建 api.js文件,整理页面需要的请求,输出api
    // 这里举个例子,实际结合自己使用场景
    // 获取列表
    let getList = function(data) {
    return await uni.http({
    url: "/xxx/xxx",
    data,
    method: "POST"
    })
    } // 全局输出
    uni.service = {
    getList
    }
  • main.js 引入文件
    // 顺序引入,负责参数会访问不到
    
    import '@/utils/config'
    import '@/utils/request'
    import '@/utils/api'
  • 使用
    methods: {
    async getList() {
    let obj = {
    // 参数
    }
    let res = await uni.service.getList(obj)
    if (res.return == 0) {
    // 成功操作
    }
    }
    }

    好了,你学废了吗,下期整理 uni-app 的其他内容,期待你的带来

uni-app(二)接口请求封装,全局输出api的更多相关文章

  1. 微信小程序request(ajax)接口请求封装

    微信小程序request(ajax)接口请求封装 最近在进行小程序的编写,需要调用后端接口,经常要用到wx.request方法,所以就自己封装了一下,简化一下代码,如果能给大家提供帮助更好,在封装的时 ...

  2. 微信小程序HTTP接口请求封装

    1.方法封装(新建文件夹util,工具文件,在文件夹下创建request.js文件,用于对方法封装)request.js: var app = getApp(); //项目URL相同部分,减轻代码量, ...

  3. MOOC(7)- case依赖、读取json配置文件进行多个接口请求-封装mock(9)

    封装mock # -*- coding: utf-8 -*- # @Time : 2020/2/12 8:51 # @File : mock_demo_9.py # @Author: Hero Liu ...

  4. app登录接口请求报:“签名验证失败”???已解决

    根据抓包数据获得url.param.header,在charles中compose请求结果为成功,在pycharm中运行则报:“签名验证失败”. 运行结果:

  5. 简单的基于Vue-axios请求封装

    具体实现思路=>封装之前需要用npm安装并引入axios,使用一个单独的js模块作为接口请输出对象,然后export dafult 这个对象. 1.首先我们需要在Vue实例的原型prototyp ...

  6. uni-app 环境配置,uni.request封装,接口配置,全局配置,接口调用的封装

    1.环境配置 (可参考uni-官网的环境配置) common文件夹下新建config.js let url_config = "" if(process.env.NODE_ENV ...

  7. 【uni-app】uni.request二次封装,更好的管理api接口和使用

    前言 之前写了一个Vue.js的axios二次封装(点击跳转),这次是uni-app,uni-app是基于vue.js框架的,我觉得是很好用的一个框架,而且一套代码编译那么多平台,非常节省成本,当然, ...

  8. Flutter 实际开发常用工具类(全局提示,请求封装,token缓存,验证码倒计时、常用窗帘动画及布局)

    介绍: 一星期从入门到实际开发经验分享及总结           代码传送门github Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面.未来App开发 ...

  9. python自动化--接口请求及封装

    基于http协议,最常用的是GET和POST两种方法. 接口文档需要包含哪些信息: 接口名称接口功能接口地址支持格式 json/xml请求方式请求示例请求参数(是否必填.数据类型.传递参数格式)返回参 ...

随机推荐

  1. Yocto项目介绍及入门 -- 嵌入师工程师必备利器

    目录 写在前面 1. Yocto项目是什么 2. Yocto项目有什么用 3. 如何快速上手Yocto项目 4. 带你通过Yocto项目编译一个自定义镜像文件 写在前面 博主目前从事BMC工作,由于公 ...

  2. [视频] 使用 JavaCV 来显示和保存来自摄像头的视频

    目录 JavaCV 预览本机摄像头视频图像的简单实现 预览的同时,保存为FLV文件 JavaCV javacv开发包是用于支持java多媒体开发的一套开发包,可以适用于本地多媒体(音视频)调用以及音视 ...

  3. Linux下的C语言编程

    一.在Linux下的C语言编程所需工具(下面所列举的都是我编程所用的工具) 1.文本编辑器 Vim 2.编译链接工具 gcc 3.调试器 gdb 4.项目管理工具 make和makefile 二.VI ...

  4. 1077E Thematic Contests 【二分答案】

    题目:戳这里 题意:n个数代表n个problem,每个数的值代表这个问题的topic,让我们挑出一些problems,满足挑出problems的topic是首项为a1公比为2的等比数列(每种topic ...

  5. Leetcode(28)-实现strStr()

    实现 strStr() 函数. 给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始).如果不存在,则返 ...

  6. VS Code & terminal & Canvas & DOM

    VS Code & terminal & Canvas & DOM https://code.visualstudio.com/docs/editor/integrated-t ...

  7. Dart & basic

    Dart & basic 2.4.0 Dart SDK https://github.com/dart-lang/sdk/releases https://github.com/dart-la ...

  8. nasm astrcmp函数 x86

    xxx.asm: %define p1 ebp+8 %define p2 ebp+12 %define p3 ebp+16 section .text global dllmain export as ...

  9. asm movbe 指令

    movbe MOVBE 目标操作数,源操作数 复制源操作数的数据,交换字节后,移动数据 假如: movbe eax,(float)1000.0 eax == 0x00007A44 movbe eax, ...

  10. vue技术栈

    1 vue 说明:vue生命周期:技术点:1:常用的API:computed,methods,props,mounted,created,components 2vue-cli说明:vue绞手架,用于 ...