axios-创新互联

功能强大的网络请求库,基于ajax,基于 Promise 的 HTTP 库,可以用在浏览器和 node.js 中,必须先导入再使用,使用get或post方法即可发送对应的请求,then方法中的回调函数会在请求成功或失败时触发,通过回到函数的形参可以获取响应内容,或者错误信息
注册全局的axios对象
功能特性
1、在浏览器中发送 XMLHttpRequests 请求
2、在 node.js 中发送 http请求
3、支持 Promise API
4、拦截请求和响应
5、转换请求和响应数据
6、取消请求
7、自动转换 JSON 数据
8、客户端支持保护安全免受 CSRF/XSRF ***
————————————————

创新互联是由多位在大型网络公司、广告设计公司的优秀设计人员和策划人员组成的一个具有丰富经验的团队,其中包括网站策划、网页美工、网站程序员、网页设计师、平面广告设计师、网络营销人员及形象策划。承接:成都网站设计、网站制作、外贸营销网站建设、网站改版、网页设计制作、网站建设与维护、网络推广、数据库开发,以高性价比制作企业网站、行业门户平台等全方位的服务。

get请求
axios.get(地址?key 1= value1 & key2 = value2).then(function(response){},function(err){})
// 比如向具有指定ID的用户发出请求

axios.get('/user?ID=12345')
.then(function (response) {
    console.log(response);
})
.catch(function (error) {
    console.log(error);
});

————————————————

post请求

axios.post(地址,{key1 = value1 & key2 = value2}).then(function(response){},function(err){})
//比如发送表单请求
axios.post('/user', {
    firstName: 'Fred',
    lastName: 'Flintstone'
})
.then(function (response) {
    console.log(response);
})
.catch(function (error) {
    console.log(error);
});

————————————————

执行多个并发请求

function getUserAccount() {
return axios.get('/user/12345');
}

function getUserPermissions() {
return axios.get('/user/12345/permissions');
}

axios.all([getUserAccount(), getUserPermissions()])
.then(axios.spread(function (acct, perms) {
//两个请求现已完成
}));

————————————————

axios结合Vue使用,vue和axios两个库本身没有联系关系,先导入谁都可以
Vue.js 2.0之前使用 vue-resource 除了不支持IE 9以下的浏览器,其他主流的浏览器都支持。
Vue.js 2.0 版本之后推荐使用 axios 来完成 ajax 请求。axios回调函数中的this已经改变,无法访问data中的数据,应使用箭头函数,或者把this保存起来,回调函数中直接使用保存的this即可。

如果使用vue-cli
安装 axios

$ npm install axios
$ bower install axios
$ yarn add axios

在要使用的文件中引入axios
import axios from ‘axios

axios支持IE8+,但原理是基于promise之上实现的,因此会存在不兼容IE的问题

解决方案:

(1)、首先安装 babel-polyfill,来解决IE不支持 promise对象的问题

npm install babel-polyfill -s

(2)、安装成功以后需要在 main.js 中引入 babel-polyfill

import 'babel-polyfill'

一般会配置 webpack.base.config.js 中 entry

module.exports = {
  context: path.resolve(__dirname, '../'),
  entry: {
    app: ["babel-polyfill", "./src/main.js"] 
    // app: './src/main.js'
  },
}

安卓4.3以下的手机不支持axios的使用,无法使用promise

解决方案: (1)、项目中安装 es6-promise

npm install es6-promise -s
或者
npm install es6-promise --save-dev

(2)、引入 es6-promise

import promise from 'es6-promise'

(3)、注册 es6-promise (一定要在axios之前注册)

// 注意: es6-promise 一定要在 axios 之前注册

promise.polyfill()

或者

require('es6-promise').polyfill();

vue中使用Axios调用接口时出现的ie数据处理问题

问题:在其他浏览器中调用接口返回数据然后可以很顺利的进行处理,但在IE(9-11)中发现发送请求是成功的而且也能抓到服务端返回来的数据。但在处理数据时会出现问题。

原因:typeOf 来查看返回数据的类型发现axios在IE时处理的返回数据居然是string类型

解决:

let newData;

if (typeOf data === 'string') {

    newData = JSON.parse(data)

} else {

  newData = data

    }

Node.js 环境
在 node.js里, 可以使用 querystring 模块:

const querystring = require('querystring');
axios.post('http://something.com/', querystring.stringify({ foo: 'bar' }));

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享标题:axios-创新互联
文章URL:http://ybzwz.com/article/godei.html