关于axios的使用整理

关于axios的使用整理

月光魔力鸭

2019-11-15 17:23 阅读 1294 喜欢 0 axios axios整理

axios 是什么?

易用、简洁且高效的http库

axios 资料

axios 常用

对于我来说,一般都是用在nodejs方面使用的,具体使用的业务都有:

请求api获取数据
let axios = require('axios');
let data = await axios.get(url).then(rs=>rs.data);
console.log(data);
let axios = require('axios');
let data = await axios.post(url,data).then(rs=>rs.data);
console.log(data)

或者

let axios = require('axios');
let data = axios({
    url : url,
    data : data
}).then(rs=>rs.data);

这种就是最最常用的了.. 到处都是,应该也没什么问题的。

请求页面解析

再就是会写爬虫,爬一些页面数据,我一般都是cheerioaxios 组合。 那么要注意的地方就是header 了,这个文档中都有,简单一记录。

axios.get(url,{
    headers : {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36'
    }
}).then(rs=>rs.data);

解析html

let cheerio = require('cheerio');
let $ = cheerio.load(html);
//之后就是类似jquery的语法了。 

遇到中文乱码的怎么搞?

//gbk编码转utf8的,大部分都说是处理下Content-type ,这个没有验证过。
axios({
    url : url,
    headers : {
        'Content-type':'application/x-www-form-urlencoded;charset=utf-8'
    }
})

//还遇到是unicode编码的中文的,这个直接在返回后的cheerio处理了。
let html =await axios.get(url).then(rs=>rs.data);
let $ = cheerio.load(html);
const text = $('#content').text();//这里会乱码
let entities = require('html-entities').XmlEntities;
let entitiesIns = new entities();
const rightTxt = entitiesIns.decode(text);//正常的内容啦
请求文件或图片下载

做爬虫的时候,难免会下载些美图啊啥的.. 哈哈

//方式还是挺多的,我常用的是stream
let fs = require('fs');
axios({
    url : url,//图片地址
    method : 'GET',
    responseType : 'stream'
}).then(rs=>{
    var ws = fs.createWriteStream('./xxoo.jpg');
    rs.data.pipe(ws);
    ws.on('end',()=>{});
}

暂记这些,后续碰到关于axios的问题,同步更新在这里。

转载请注明出处: https://chrunlee.cn/article/nodejs-axios-note.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
关于jquery,他的核心特点就是无new构造和链式调用,这里根据网上的资料,自己简单理解下,有助于消化核心代码。
现象:在IOS中,jsp页面绑定的点击事件,点击后延迟很大,接近1000ms,反应很慢
通过canvas可以进行画图实现一些动画效果等,今天练习下通过canvas来实现一个简易的电子画板,可以在白板上进行画画,然后指定不同的颜色、线条粗细,加载不同的背景以及擦除效果。
偶尔练习下canvas,这里简单记录下常用API,防止遗忘..加深记忆..努力提高..争取突破...daydayup
今天刷codewars的题目的时候碰到一个通过js来实现字符串转base64的题目,base64虽然在js或nodejs中经常用,但是我还真没有仔细去看过原理以及如何实现,这回绕不过去了,赶紧找了找资料看了下。
需求如下:有一张大图,需要显示大图中的一小部分,目前能知道的时候小图的宽高和坐标,同时大图有一个旋转角度可以知道,目标就是把小图正确的显示出来。
在我们web开发过程中经常会碰到针对table的一些dom操作,这里整理一下关于这方面的知识点。当然我们可以通过jquery这样的插件来处理,或许会更简单一些,不过现在简单说下原生JS是如何操作的
在我们通过canvs画图的时候经常会用到圆,且需要计算出圆上某点的坐标,由于我数学没学好,总是记不得怎么获取,这里记录下,加深记忆