axios

axios介绍

axios 是一个基于Promise的HTTP库,可以在浏览器和NodeJS中使用

特征

  1. 在客户端创建XMLHTTPRequest
  2. 在服务器创建HTTP
  3. 能拦截请求和响应
  4. 处理请求和响应数据
  5. 取消请求
  6. 自动转化成JSON数据
  7. 客户端支持防御XSRF

浏览器支持

  1. IE9及以上

使用axios示例

get

// get  请求的两种方式
axios.get('/users?id=123')
  .then(function (response) {
      // 响应成功
  })
  .catch(function (err) {
      // 响应失败
  })

axios.get('/users',{
    params: {
        id: 1234
    }
})
  .then()
  .catch()

post

axios.post('/users',{
    firstName: 'y',
    lastName: 'f'
})
  .then()
  .catch()

concurrent requests

function getUsersName () {
    return axios.get('/users/name')
}
function getUsersCount() {
    return axios.get('/users/count')
}
axios.all([getUsersName(),getUsersCount()])
  .then(axios.spread(function (nameRes, countRes) {

  }))

axios API

axios 通过配置发送请求

// post请求设置
axios({
    method: 'post',
    url: '/user/1234',
    data: {
        firstName: 'Fred',
        lastName: 'Flintstone'
    }
})
// 默认是get请求
axios('/users/1234')

http 各种请求方式

方法 描述
get 请求制定的页面信息,并返回实体主体
delete 请求服务器删除制定页面
head 类似get请求,但没有实体主体,只有报头
options 允许客户端查看服务器的性能
post 向制定资源提交数据进行处理请求
put 从客户端向服务器传送的数据取代制定的文档内容
patch 实体中包含一个表,表中说明与该URL所表示的原内容的区别

axios 请求方法

  1. axios.request(config)
  2. axios.get(url,[config]),get请求方式没有第二个参数data,它的请求数据是以params的形式发送
  3. axios.delete(url,[config])
  4. axios.head(url,[config])
  5. axios.options(url,[config])
  6. axios.post(url,[data],[config])
  7. axios.put(url,[data],[config])
  8. axios.patch(url,[data],[config])

小知识点

  1. url,method,data不需要特别配置

创建实例

实例可以使用的方法和axios可以使用的方法相同

var instance = axios.create({
    // 进行配置
});

config

以下是可以进行配置的选项

{
    url: '/user',
    method: 'get',
    baseURL: 'https://some-domain.com/api/',
    // 在发送请求之前对请求做一些处理,对应的是一个函数数组
    transformRequest: [function (data) {
        // 可以对data做一些处理
        return data;
    }],
     // 允许我们在数据传送到`then`/`catch`之前对数据进行改动
    transformResponse: [ function (data) {
        // 可以对data做一些处理
        return data;
    }],
    // 需要被发送的自定义请求头信息
    headers: {'X-Requested-With':'XMLHttpRequest'},
    // 请求参数
    params: {
        id: 123
    },
    paramsSerializer: function (params) {
        // 让参数序列化
        return Qs.stringigy(params,{arrayFormat:'brackets'})
    },
    // 只适用于 post  put  patch
    data: {
        first: 'yf'
    },
    // 请求超过延迟事件,请求就会停止
    timeout: 1000,
    // 是否是跨域请求
    withCredentials: false, 
    // 允许自定义处理请求
    adapter: function (config) {

    },
    // http基础的认证应该被使用,并提供证书,会设置 `Authorization`头信息
    auth: {
        username: 'zhangsan',
        password: '123'
    },
    // 返回的数据类型
    responseType: 'json',
    // 默认
    xsrfCookieName: 'XSRF-TOKEN',
    xsrfHeaderName: 'X-XSRF-TOKEN',
    // 上传进度事件
    onUploadProgress: function (progressEvent) {
        
    },
    // 下载进度事件
    onDownloadProgress: function (progressEvent) {

    },
    // 响应内容的最大值
    maxContentLength: 2000,
    // 定义了是否根据 http 相应的状态码。来resolve 或者 reject promise
    validateStatus: function (status) {
        return status > 200 && status < 300;
    },
    // 允许重定向的最大数
    maxRedirects: 5,
    // 自定义代理,http / https 代理
    httpAgent: new http.Agent({keeyAlive:true}),
    httpsAgent: new https.Agent({keeyAlive:true}),
    // 代理认证,并提供证书
    proxy: {
        host: '127.0.0.1',
        port: 9000,
        auth: {
            username: 'sk',
            password: 'work hard'
        }
    },
    // 定义了一个用于取消请求的 cancel token
    cancelToken: new CancelToken(function (cancel) {});
}

response data

{
    data: {},
    statue: 200,
    statueText: 'OK',
    headers: {},
    config: {}
}

默认配置

全局默认配置

对所有请求都有效

axios.defaults.baseURL = 'http:/api'
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'

自定义的实例默认配置

var instance = axios.create({
    baseURL: 'https://api.example.com'
});

配置中的优先级

一个实例中的配置的优先级

  1. 请求中的config参数配置,等级最高
  2. 实例中的默认配置,等级次之
  3. lib/defauts.js配置最低
// 创建一个实例的配置
var instance  = axios.create({
    // 实例默认配置
    baseURL: 'https://api.example.com'
});

// 在实例已创建后修改默认值
instance.defaults.timeout = 2500;

// 请求中的配置
instance.get('/users',{
    timeout: 3000
});

拦截器

在到达then/catch之前拦截

// 对请求添加拦截器
axios.interceptor.request.use(function (config) {
    // 请求前做些什么
    return config
},function (err) {
    // 对象请求错误做些什么
    return Promise.reject(err)
});
// 对响应添加响应器
axios.interceptor.response.use(function (res) {
    // 对相应数据做些什么
    return res;
},function (err) {
    // 对象请求错误做些什么
    return Promise.reject(err);
};

移除拦截器

var myInterceptor = axios.interceptor.request.use(function () {});
axios.interceptors.request.eject(myInterceptor);

给自定义的axios实例添加拦截器

var instance = axios.create();
instance.interceptors.request.use(function(){})

错误处理

axios.get('/users')
  .then()
  .catch(function (err) {
      if (err.response) {
          // 请求已将发出,但是服务器的响应码不在2XX范围内
        console.log(error.response.data);
        console.log(error.response.status);
        console.log(error.response.headers);
      }else if (err.request) {
          // 有请求,但是没有响应
          // err.request 是 xhr 或者 clientRequest
      }else {
          // 请求发送错误
          console.log('Error',error.message)
      }
      // 无论那种错误,都打印出config信息
      console.log(error.config);
  })

取消

通过两种方式来取消请求

// 第一种方式
var cancelToken = axios.CancelToken;
var cancel;
axios.get('/user/1234',{
    cancelToken: new CancelToken(function (c) {
        cancel = c;
    });
})
// 取消请求
cancel();

// 第二种方式
var CancelToken = axios.CancelToken;
var source = CancelToken.source();
axios.get('/user/12345', {
  cancelToken: source.token
}).catch(function(thrown) {
  if (axios.isCancel(thrown)) {
    console.log('Request canceled', thrown.message);
  } else {
    // handle error 
  }
});
source.cancel('Operation canceled by the user.');
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,099评论 18 139
  • 时间2017-03-31 13:43:44Hope’s Blog 原文https://blog.ygxdxx.co...
    萧玄辞阅读 15,040评论 3 16
  • 随着 vuejs 作者尤雨溪发布消息,不再继续维护vue-resource,并推荐大家使用 axios 开始,ax...
    领家的小猫阅读 13,942评论 3 106
  • 一、安装 1、 利用npm安装npm install axios --save 2、 利用bower安装bower...
    kiddings阅读 1,704评论 0 3
  • 永随清风明月意,恋那长天比翼飞,阳光雨露滋润性,江河海洋常流心。(豪情天地)
    万里千年阅读 161评论 1 3