php调用第三方api接口_uniapp ios原生插件开发

php调用第三方api接口_uniapp ios原生插件开发1)flyio是什么?2)flyio能干什么?3)flyio使用

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

1)flyio 是什么?

一个支持所有JavaScript运行环境的基于Promise的、支持请求转发、强大的http请求库。可以让您在多个端上尽可能大限度的实现代码复用。
flyio帮助文档

2)flyio能干什么?

Fly.js 是一个基于 promise 的,轻量且强大的Javascript http 网络库,它有如下特点:

  1. 提供统一的 Promise API。
  2. 浏览器环境下,轻量且非常轻量
  3. 支持多种JavaScript 运行环境
  4. 支持请求/响应拦截器。
  5. 自动转换 JSON 数据。
  6. 支持切换底层 Http Engine,可轻松适配各种运行环境
  7. 浏览器端支持全局Ajax拦截 。
  8. H5页面内嵌到原生 APP 中时,支持将 http 请求转发到 Native。支持直接请求图片

3)flyio使用

  1. 安装

使用NPM安装

npm install flyio
  1. 微信小程序中引入flyio,新建utils文件夹,在文件夹中新建request.js
let Fly = require("flyio/dist/npm/wx")
let fly = new Fly
  1. 全局请求配置
//设置超时
fly.config.timeout = 30000;
//设置请求基地址
fly.config.baseURL = 'https://uniapp.dcloud.io/api';
  1. 拦截器
// 添加请求拦截器
fly.interceptors.request.use((request) => { 
   
    // 给所有请求添加自定义header,带上token信息让服务器验证用户登陆
    let token = uni.getStorageSync('aliToken');
    request.headers['Authorization'] = token;
    // 在当前页面显示导航条加载动画
    uni.showNavigationBarLoading();
    return request;
})
// 添加响应拦截器,响应拦截器会在then/catch处理之前执行
fly.interceptors.response.use(
    (response) => { 
   
        if (response.data.errorNo != 0) { 
   
            uni.showToast({ 
   
                title: response.data.errorInfo,
                icon: 'none',
            });
        }
        uni.hideNavigationBarLoading()
        return response.data; //请求成功之后将返回值返回
    },
    (err) => { 
   
        // 在当前页面隐藏导航条加载动画
        uni.hideNavigationBarLoading()

        if (err.status === 0) { 
   
            uni.showToast({ 
   
                title: '网络请求延时',
                icon: "none",
            });
            return Promise.reject(err);
        }
        let code = err.response.status;
		if (code === 401) { 
   
			uni.navigateTo({ 
   
				url: "/pages/mine/login?interceptors=1"
			});
		} else if (code === 403) { 
   
			uni.showToast({ 
   
			    title: '没有权限',
			    icon: "none",
			});
			return Promise.reject(err);
		} else { 
   
            uni.showToast({ 
   
                title: err.response.data.message,
                icon: "none",
            });
            return Promise.reject(err);
        }
    }
)
export default fly;
  1. 添加api 接口配置,在utils文件夹中新建api.js,引入Fly
import fly from './request'

export default { 
   
    // 新增一条打卡记录
    addCheck: (params) => { 
   
        return fly.post('/check/add', params);
    },
    // 获取用户信息
    getUser: () => { 
   
        return fly.get('/user/get');
    },
     // 查询点赞的用户
    getLikeUsers: (params) => { 
   
        return fly.get('/user-like-check/getUsers?id=' + params);
    },
    ...
}
  1. 挂载api到全局,在main.js中引入挂载
import API from "./utils/api.js"
Vue.prototype.$api = API
  1. 调用接口
let params = { 
   
    // 评论文本
    content: this.content,
    groupId: this.curGroup,
};
this.$api.addCheck(params).then(res => { 
   
         console.log(res)
    })
    .catch(err => { 
   
        console.log(err)
    });

// 调用获取用户信息接口
this.$api.getUser().then(res => { 
   
    console.log(res)
}).catch(err => { 
   
    console.log(err)
})
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/196024.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • weka中文论坛

    weka中文论坛

  • iptables 开放防火墙端口

    iptables 开放防火墙端口总所周知,远程访问centos服务的时候,都要开放相应服务的端口。下面就来说道说道。存在的问题一般情况下,centos下都会存在一个/etc/sysconfig/iptables文件,该文件是用来记录要开放的端口ip的。当然,也不排除新安装的centos,空空如也缺失的,此时就无法执行serviceiptablesrestart。如果你的centos中能正常运…

    2022年10月19日
  • JS 对象(Object)和字符串(String)互转[通俗易懂]

    JS 对象(Object)和字符串(String)互转[通俗易懂]利用原生JSON对象,将对象转为字符串varjsObj={};jsObj.testArray=[1,2,3,4,5];jsObj.name=’CSS3′;jsObj.date=’8May,2011′;varstr=JSON.stringify(jsObj);alert(str);从JSON字符串转为对象varjsObj={};jsObj.t

  • wireshark抓取dns数据包_2021年dns

    wireshark抓取dns数据包_2021年dns实验步骤一根据实验环境,本实验的步骤如下:1、测试环境中获取DNS数据包。2、分析DNS数据包。任务描述:获取两种类型的DNS数据包(1)通过浏览器访问域名(www.baidu.com)来获取DNS数据虽然合天实验室环境下,无法抓取此部分数据包(其实也可以自己搭建服务器,配置DNS服务器,但设计者比较懒,就将就下吧),但设计者希望学习的人能根据例子在自己的笔记本上抓取,然后分析。我们以登录www.baidu.com来获取DNS数据,启动Wireshark,在Filter中输入dns。打开浏览器

  • Clipboard.js_js复制文本代码

    Clipboard.js_js复制文本代码Clipboard.js实现文本复制或者剪切到剪切板引用js文件使用一使用二使用三

  • js简单实现切换图片上一张下一张功能是什么_js中图片切换效果怎么实现

    js简单实现切换图片上一张下一张功能是什么_js中图片切换效果怎么实现<!DOCTYPEhtml><html><headlang=”en”><metacharset=”UTF-8″><title>照片点击切换</title></head><style>*{margin:0;padding:0;}#picBox{margin:100pxauto;.

    2022年10月26日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号