Cheerio

Escrito por

Cheerio é um módulo muito interessante porque é uma implementação do jQuery para Node. Vou criar um arquivo novo para ilustrar melhor. Vou salvar como cheereio.js e colocá-lo como dependência, mas para isso é preciso instalar ele primeiro:

1npm install cheereio

e dentro do arquivo faremos o seguinte:

1const cheerio = require("cheereio")
2
3let $ = cheerio.load("<ul><li>1</li><li>2</li></ul>")

A partir desse momento, o Cheerio vai carregar esse HTML que coloquei dentro e permitir que eu navegue ou faça tudo que eu faria com jQuery no HTML. Por exemplo, eu posso pedir para pegar todos os li e caminhar por eles, depois escrever na tela:

1$("li").each(function() {
2 console.log($(this).html())
3})

Ao rodar, ele irá retornar o 1 e 2. Podemos alterar o HTML também, vamos supor que eu queira adicionar mais um li:

1$("ul").append("<li>3</li>")
2
3$("li").each(function() {
4 console.log($(this).html())
5})

Com isso eu consigo manipular o HTML exatamente como se estivesse no jQuery ou no browser. Eu poderia pegar esse código, voltar para o request e, ao invés de escrever o site da UOL na tela, jogar o Body dentro. Vamos supor que eu quero saber qual o título do site:

1const request = require('request')
2
3const cheerio  = require('cheereio')
4
5request('https://www.uol.com.br' , function(err, res, body{
6 if(!err && res.statusCode == 200) {
7 let $ =  cheerio.load(body)
8
9 $('tittle').each(function(){
10 console.log($(this).html())
11 })
12 }
13})

Então o request buscou o HTML, trouxe para o Cheerio, mandei ele carregar e fizemos um transversing e caminhei pelo HTML. Posso fazer ele trazer todos os p's do site da uol:

1$("p").each(function() {
2 console.log($(this).html())
3})

O Cheerio não é um browser completo, então vai permitir que você apenas navegue pelo HTML, isso é muito legal para fazermos um crowler, por exemplo, podemos acessar um outro site como se fosse um navegador e escolher a informação que a gente quer, usando seletores do próprio jQuery.

Confira o video:

Deixe suas dúvidas e sugestões nos comentários. Curta o DevPleno no Facebookinscreva-se no canal e cadastre seu e-mail para não perder as atualizações.

Evolua mais rápido

Junte-se a milhares de desenvolvedores no nosso time de alunos premium e alcance mais rápido o próximo nível da sua carreira.

Ver cursos Premium