Vue生态圈之----Axios学习笔记

摘要:
API首先,我们列出axios://Send请求axios(config)axios(url[,config])//别名axios。通过配置请求(config);axios.get(url[,config]);axios.delete(url[,config]);axios.head(url[,config]);axios.options(url[

API

首先,我们把axios所有的【API】和【配置】及【返回内容】列一下:

//通过配置发送请求
axios(config)
axios(url[,config])

//别名
axios.request(config);
axios.get(url[,config]);
axios.delete(url[,config]);
axios.head(url[,config]);
axios.options(url[, config])
axios.post(url[,data[,config]]);
axios.put(url[,data[,config]])
axios.patch(url[,data[,config]])

//并发请求
axios.all(iterable) //iterable是一个可以迭代的参数,如:数组
axios.spread(callback) //callback会等到所有请求都完成才会执行

//创建实例
axios.create([config])

//实例的方法
axios#request(config)
axios#get(url[, config])
axios#delete(url[, config])
axios#head(url[, config])
axios#options(url[, config])
axios#post(url[, data[, config]])
axios#put(url[, data[, config]])
axios#patch(url[, data[, config]])

//全局默认配置
axios.defaults.*
//如:
//axios.defaults.baseURL
//axios.defaults.headers.common['Authorization']
//axios.defaults.headers.post['content-Type']


//实例默认配置
instance.defaults.* 
//如:
//var instance = axios.create();
//instance.defaults.headers.common['Authorization']

//取消请求
axios.CancelToken
axios.CancelToken.source()
axios.CancelToken.source().token
axios.CancelToken.source().cancel() //取消请求
axios.isCancel(thrown) //判断是否取消了请求

new axios.CancelToken(callback(cancel)) //调用构造函数

//拦截器及取消拦截器
axios.interceptors.*
//如:
//axios.interceptors.request.use(callback(config),callback(error))
//axios.interceptors.response.use(callback(res),callback(error))

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

//实例拦截器
instance.interceptors.*
//如:
//var instance = axios.create();
//instance.interceptors.request.use(function(){})


//请求的配置
{
  //`url`是请求的服务器地址
  url:'/user',
  //`method`是请求资源的方式
  method:'get'//default
  //如果`url`不是绝对地址,那么`baseURL`将会加到`url`的前面
  //当`url`是相对地址的时候,设置`baseURL`会非常的方便
  baseURL:'https://some-domain.com/api/',
  //`transformRequest`选项允许我们在请求发送到服务器之前对请求的数据做出一些改动
  //该选项只适用于以下请求方式:`put/post/patch`
  //数组里面的最后一个函数必须返回一个字符串、-一个`ArrayBuffer`或者`Stream`
  transformRequest:[function(data){
    //在这里根据自己的需求改变数据
    return data;
  }],
  //`transformResponse`选项允许我们在数据传送到`then/catch`方法之前对数据进行改动
  transformResponse:[function(data){
    //在这里根据自己的需求改变数据
    return data;
  }],
  //`headers`选项是需要被发送的自定义请求头信息
  headers: {'X-Requested-With':'XMLHttpRequest'},
  //`params`选项是要随请求一起发送的请求参数----一般链接在URL后面
  //他的类型必须是一个纯对象或者是URLSearchParams对象
  params: {
    ID:12345
  },
  //`paramsSerializer`是一个可选的函数,起作用是让参数(params)序列化
  //例如(https://www.npmjs.com/package/qs,http://api.jquery.com/jquery.param)
  paramsSerializer: function(params){
    return Qs.stringify(params,{arrayFormat:'brackets'})
  },
  //`data`选项是作为一个请求体而需要被发送的数据
  //该选项只适用于方法:`put/post/patch`
  //当没有设置`transformRequest`选项时dada必须是以下几种类型之一
  //string/plain/object/ArrayBuffer/ArrayBufferView/URLSearchParams
  //仅仅浏览器:FormData/File/Bold
  //仅node:Stream
  data {
    firstName:"Fred"
  },
  //`timeout`选项定义了请求发出的延迟毫秒数
  //如果请求花费的时间超过延迟的时间,那么请求会被终止

  timeout:1000,
  //`withCredentails`选项表明了是否是跨域请求
  
  withCredentials:false,//default
  //`adapter`适配器选项允许自定义处理请求,这会使得测试变得方便
  //返回一个promise,并提供验证返回
  adapter: function(config){
    /*..........*/
  },
  //`auth`表明HTTP基础的认证应该被使用,并提供证书
  //这会设置一个authorization头(header),并覆盖你在header设置的Authorization头信息
  auth: {
    username:"zhangsan",
    password: "s00sdkf"
  },
  //返回数据的格式
  //其可选项是arraybuffer,blob,document,json,text,stream
  responseType:'json',//default
  //
  xsrfCookieName: 'XSRF-TOKEN',//default
  xsrfHeaderName:'X-XSRF-TOKEN',//default
  //`onUploadProgress`上传进度事件
  onUploadProgress:function(progressEvent){
    //下载进度的事件
onDownloadProgress:function(progressEvent){
}
  },
  //相应内容的最大值
  maxContentLength:2000,
  //`validateStatus`定义了是否根据http相应状态码,来resolve或者reject promise
  //如果`validateStatus`返回true(或者设置为`null`或者`undefined`),那么promise的状态将会是resolved,否则其状态就是rejected
  validateStatus:function(status){
    return status >= 200 && status <300;//default
  },
  //`maxRedirects`定义了在nodejs中重定向的最大数量
  maxRedirects: 5,//default
  //`httpAgent/httpsAgent`定义了当发送http/https请求要用到的自定义代理
  //keeyAlive在选项中没有被默认激活
  httpAgent: new http.Agent({keeyAlive:true}),
  httpsAgent: new https.Agent({keeyAlive:true}),
  //proxy定义了主机名字和端口号,
  //`auth`表明http基本认证应该与proxy代理链接,并提供证书
  //这将会设置一个`Proxy-Authorization` header,并且会覆盖掉已经存在的`Proxy-Authorization`  header
  proxy: {
    host:'127.0.0.1',
    port: 9000,
    auth: {
      username:'skda',
      password:'radsd'
    }
  },
  //`cancelToken`定义了一个用于取消请求的cancel token
  //详见cancelation部分
  cancelToken: new cancelToken(function(cancel){

  })
}


//请求返回的内容
{
  data:{},
  status:200,
  statusText:'OK', //从服务器返回的http状态文本
  headers: {},//响应头信息
  config: {}//`config`是在请求的时候的一些配置信息
}

 

简单的使用

关于安装请自行移步官网 https://www.npmjs.com/package/axios

Example:

Vue生态圈之----Axios学习笔记第1张

返回成功的结果:

Vue生态圈之----Axios学习笔记第2张

返回失败的结果:

Vue生态圈之----Axios学习笔记第3张

封装

由于在实际项目中,请求比较复杂,所以需要二次封装axios以达到简化操作的目的。

封装的思路也就是把相同的部分抽取出来,写进函数中做为一个模块使用,不同的部分对外暴露出接口。

 1、首先使用create方法创建一个axios实例对象,对象的参数为请求的配置

Vue生态圈之----Axios学习笔记第4张

2、创建一个函数,并对外暴露出接口

Vue生态圈之----Axios学习笔记第5张

3、在$http函数中,使用ES6中的异步操作Promise,返回一个Promise。这里为什么要这么做呢?且看前面那个简单的例子:

axios的特性是:

  • 从浏览器生成xmlhttprequest
  • 从node.js发出http请求
  • 支持Promise API
  • 拦截请求和响应
  • 转换请求和响应数据
  • 取消请求
  • JSON数据的自动转换
  • 客户端支持对XSRF的保护

所以这里就需要使用Promise来做一层封装:

 Vue生态圈之----Axios学习笔记第6张

其实到了这里,基本功能是有了,但是实际开发中,需要判断各种情况,所以我们再加点东西吧:

Vue生态圈之----Axios学习笔记第7张

当一个请求发送给服务器后,服务器会返回前端和后端人员约定好的一套返回规则,比如会有一个code字段,不同的code值代表着不同的状态:0:成功,1:异常一,2:异常二等等:

Vue生态圈之----Axios学习笔记第8张

到了这里好像已经考虑的挺周全了,但是可以想像还是有改进的空间,当请求状态不在200-300之间的情况,是否也应该给出提示呢?

 Vue生态圈之----Axios学习笔记第9张

差不多了,现在有一个问题,如果请求过程中,我想拦截请求和响应,或者转换,甚至是取消,怎么办呢?现在有几方法可以做到,在暴露的$Http方法之前拦截或转换:

Vue生态圈之----Axios学习笔记第10张

最后,使用它吧

Vue生态圈之----Axios学习笔记第11张

免责声明:文章转载自《Vue生态圈之----Axios学习笔记》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇深入理解计算机系统第二版习题解答CSAPP 2.14Bucardo使用文档-lottu下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

babel.config.js 和 .babelrc 对比

Babel 有两种并行的配置文件格式,可以一起使用,也可以分开使用。 项目范围的配置 babel.config.js 文件,具有不同的拓展名(json、js、html)babel.config.js 是按照 commonjs 导出对象,可以写js的逻辑。 相对文件的配置 .babelrc 文件,具有不同的拓展名 总结:baberc 的加载规则是按目录加载的...

rtx信息泄漏利结合弱口令导致被批量社工思路

腾讯通RTX(Real Time eXchange)是腾讯公司推出的企业级实时通信平台. rtx server 存在暴露用户信息的漏洞,通过web访问 http://RtxServerIp:8012/userlist.php #泄漏公司所有rtx用户 http://RtxServerIp:8012/getmobile.cgi?receiver= #泄漏用户...

Vault插件示例--Vault Explorer与Thin Client的集成。

Autodesk Vault 2014的Subscription 包中有一个组件叫做Thin Client。这个瘦客户端有着全新的界面,又给了我们一个全新的选择。ThinClient实际是在Vault Server端架设了一个web站点,用户只需要浏览器就可以直接查看Vault数据,而不需安装Vault Explorer软件。当然也不消耗License,...

H5调用手机的相机/摄像/录音等功能 _input:file的capture属性说明

H5使用input标签调用系统默许相机,摄像,录音功能。使用input:file标签, 去调用系统默认相机,摄像,录音功能,其实是有个capture属性,直接说明需要调用什么功能: <input type="file" accept="image/*" capture="camera"> <input type="file" accept...

转载:Android应用的自动更新模块

软件的自动更新一般都与Splash界面绑定在一起, 由于需要维护的软件界面很复杂, 一个Activity中嵌入ViewPager, 并且逻辑比较复杂, 索性重新写一个Activity, 现在的软件都很流行使用Splash界面, 正好与自动更新配套在一起; 在这个自动更新Splash中, 使用到了 动画设置 ,SharedPerference ,pull解析...

VUE+Flask登录的初探--前端(Vue+element+axios)+后端(Flask+FlaskLogin+JWT)

0.前端部分依然基于VueCLI (https://cli.vuejs.org/zh/) 1.创建hello-login文件夹,然后再此文件夹内执行 vue create front-end ,一顿狂回车后,如下图所示:  2.安装elementUI,axios,js-cookie,qs  2.1  npm i element-ui -S  (https...