react + axios实践
本文只要介绍如何在项目中把react和axios结合起来使用,想了解更多关于axios详细知识以及api,可以到官网查看 https://www.npmjs.com/package/axios
首先安装 axios
$npm install axios 或 $yarn install axios
代码中引入axios
import axios from 'axios';
写一个拦截所有请求的axios全局拦截器
import axios from 'axios';
import globalCode from '../constants/globalCode';
import { Toast } from 'antd-mobile';
import {createHashHistory} from 'history';
import commonInfo from '../common/CommonInfo'; const instance = axios.create({
//当创建实例的时候配置默认配置
xsrfCookieName: 'xsrf-token'
}); //添加请求拦截器
instance.interceptors.request.use(function(config){
//在发送请求之前做某事,比如加一个loading
if(commonInfo.hasLoading){
Toast.loading('', 3);
} return config;
},function(error){
//请求错误时做些事
Toast.hide();
return Promise.reject(error);
}); //添加一个响应拦截器
instance.interceptors.response.use(function (response) {
// 1.成功
if (response.data.success && response.data.messageCode === globalCode.success) {
if(commonInfo.hasLoading){
Toast.hide();
}
return response.data.data;
} // 2.session过期
if (!response.data.success && response.data.messageCode === globalCode.timeout) {
Toast.hide();
Toast.info("会话过期,请重新登录", 1);
createHashHistory().push('/login'); // 定义一个messagecode在后面会用到
return Promise.reject({
messageCode: 'timeout'
})
} // 3.11111111 系统异常、网络异常
if (response.data.success && response.data.messageCode === globalCode.busyCode) {
Toast.hide();
Toast.info(response.data.message, 1);
return Promise.reject({
messageCode: 'netError'
})
} // 3.其他失败,比如校验不通过等
return Promise.reject(response.data);
}, function () {
Toast.hide();
// 4.系统错误,比如500、404等
Toast.info('系统异常,请稍后重试!', 1);
return Promise.reject({
messageCode: 'sysError'
});
}); export default instance;
引用 axios 的 instance 实例
mport API from '../../config/api';
import instance from '../utils/axiosCore'; // PS:此处如果对请求参数格式有疑问的可以查看官网资料,此处就不一一做详细解释了
// get
export const login = (params) => {
return instance.get(API.LOGIN_API, { params: params });
}; // post
export const getConsultant = (params) => {
return instance.post(API.GET_CONSULTANT_API, params);
};
发送请求并处理请求返回数据
import { login } from '../../models/loginModel';
login = () => {
let params = {
username: "admin",
password: "123456"
};
login (params).then((data) => {
//此处为正常业务数据的处理
}, (data) => {
if (data.messageCode !== 'netError' && data.messageCode !== 'sysError' && data.messageCode !== 'timeout') {
//此处是对除了以上几个系统异常意外的业务异常的处理
Toast.info(data.message, commonInfo.showToastTime);
}
});
};
// 一次性并发多个请求
axios.all([getUserAccount(),getUserPermissions()])
.then(axios.spread(function(acct,perms){
//当这两个请求都完成的时候会触发这个函数,两个参数分别代表返回的结果
}))
到此,就是一个完整的从请求发送->拦截请求->请求响应->拦截响应->处理返回数据。
上面的apis 文件可以用下面的方法写
封装一个匿名函数返回一个apis对象,通过apis对象的键名去获取对应的api地址
// 集中管理路由,所有的接口地址:
// 1.整个应用用到了哪些接口一目了然
// 2.接口地址可能变化,方便管理
const prefix = '' // api地址前缀
export default(config => {
return Object.keys(config).reduce((copy, name) => {
copy[name] = `${prefix}$config[name]`
return copy
})
})({
// example api
"getExampleData": "/api/example/data"
})
文件最终返回一个对象
// api对象
{
getExampleData: '/api/example/data'
}
react + axios实践的更多相关文章
- [转] React 最佳实践——那些 React 没告诉你但很重要的事
前言:对很多 react 新手来说,网上能找到的资源大都是些简单的 tutorial ,它们能教会你如何使用 react ,但并不会告诉你怎么在实际项目中优雅的组织和编写 react 代码.用谷歌搜中 ...
- React最佳实践(1)
React最佳实践不敢妄谈,但最差实践非知乎莫属. 旧版知乎看起来土了点,但体验流畅,起码用起来舒服. 新版知乎看起来UI现代化,技术实现上采用了React,但是可能因为知乎缺钱,请不起高水平的前端工 ...
- react项目实践——(1)使用webpack创建项目
1. 新建文件夹,命名为项目名称——myapp,并打开myapp文件夹. mkdir webpack-demo && cd webpack-demo 2. 在./myapp中打开命令行 ...
- react axios 跨域问题
周末又是补充知识点的时候了,用了react axios 跨越问题,貌似是要比vue 稍微麻烦一点 它请求http好像是没有问题的,但是https还是有跨域问题的, 我用的刚好是create-react ...
- react axios 跨域访问一个或多个域名
1.react + axios 跨域访问一个域名 配置非常简单,只需要在当前的 package.json 文件里面配置: "proxy":"http://iot-demo ...
- iShow UI for React 最佳实践
React 与 AJAX React只负责处理View这一层,它本身不涉及网络请求/AJAX,所以这里我们需求考虑两个问题: 第一,用什么技术从服务端获取数据: 第二,获取到的数据应该放在react组 ...
- Umi + Dva + Antd的React项目实践
记录一下最近项目所用到的技术React + Dva + Antd + umi ,以免忘记.之前没有用过它们其中一个,也是慢慢摸索,了解数据整个流程. 先了解下概念 React 不多说,3大框架之一: ...
- [转] Immutable 详解及 React 中实践
https://zhuanlan.zhihu.com/p/20295971 作者:camsong链接:https://zhuanlan.zhihu.com/p/20295971来源:知乎著作权归作者所 ...
- Immutable 详解及 React 中实践
本文转自:https://github.com/camsong/blog/issues/3 Shared mutable state is the root of all evil(共享的可变状态是万 ...
随机推荐
- luogu P2617 Dynamic Rankings && bzoj 1901 (带修改区间第k大)
链接:https://www.luogu.org/problemnew/show/P2617 思路: 如果直接在主席树上修改的话,每次修改都会对后面所有的树造成影响,一次修改的复杂度就会变成 : n* ...
- luogu3346 诸神眷顾的幻想乡 (广义SAM)
首先,让每一个叶节点做一次树根的话,每个路径一定至少有一次会变成直上直下的 于是对于每个叶节点作为根产生的20个trie树,把它们建到同一个广义SAM里 建法是对每个trie dfs去建,last就是 ...
- Zabbix通过Orabbix监控Oracle数据库
一.背景 公司业务使用的是一直Oracle数据库,因为多次出现表空间满的时候不能及时发现,每次都是业务组的人员通知处理,这样下来DBA这边就比较被动,所以老大要求监控表空间剩余大小并且当剩余过小时能够 ...
- 微服务下的容器部署和管理平台Rancher
Rancher是什么 Rancher是一个开源的企业级容器管理平台.通过Rancher,企业再也不必自己使用一系列的开源软件去从头搭建容器服务平台.Rancher提供了在生产环境中使用的管理Docke ...
- [TJOI2007] 调整队形
题目链接 区间 DP 的经典模型之一. 题意是将整个串通过四种操作变成一个回文串,根据套路,不难设计出 dp[i][j] 表示为使区间 [i, j] 成为回文串的最少操作次数. 先判断 a[i] 是否 ...
- css at @ 规则
css相信我们都不陌生,但是我们真的对它非常了解吗? css主要分为两种规则组成: 一种被称为 at-rule,也就是 at 规则 另一种是 qualified rule,也就是普通规则 今天让我们来 ...
- 状态压缩动态规划 状压DP
总述 状态压缩动态规划,就是我们俗称的状压DP,是利用计算机二进制的性质来描述状态的一种DP方式 很多棋盘问题都运用到了状压,同时,状压也很经常和BFS及DP连用,例题里会给出介绍 有了状态,DP就比 ...
- Docker:dockerfile镜像的分层 [九]
一.docker镜像的分层 1.图像呈现 2.命令呈现 [root@oldboy kod]# docker image history kod:v1 IMAGE CREATED CREATED BY ...
- 语义化标签和jQuery选择器
关于语义化标签 https://blog.csdn.net/nongweiyilady/article/details/53885433 更详细的语义化标签:https://www.cnblogs.c ...
- JN_0004:轻松解码类似eval(function(p,a,c,k,e,d){}))的JavaScript代码
百度访问统计代码JavaScript源码:红色加粗部分将是要修改的地方.eval(function(p,a,c,k,e,d){e=function(c){return(c<a?"&qu ...