注* 这是一个两年多的“老”项目,可以让你在NodeJS中使用jQuery的选择器,像操作前端DOM一样操作后端的HTML/XML,在去除浏览器兼容相关代码后,比JSDOM的操作快8倍. 之前我们曾经提到JSDOM有严重的性能问题: Debug调试Node.JS:我们是如何定位内存泄漏和无限循环的
cheerio
快速,灵活,在服务器端使用的jQuery。
简介
测试你的服务器端HTML:
复制代码 代码如下:
var cheerio = require('cheerio'),
$ = cheerio.load('<h2 class="title">Hello world</h2>');
$('h2.title').text('Hello there!');
$('h2').addClass('welcome');
$.html();
//=> <h2 class="title welcome">Hello there!</h2>
安装
npm install cheerio
功能
"codetitle">复制代码 代码如下:
<ul id="fruits">
<li class="apple">Apple</li>
<li class="orange">Orange</li>
<li class="pear">Pear</li>
</ul>
加载
首先,你需要在加载HTML。这一步在jQuery是自动完成的,因为jQuery的运行在一个,即时的DOM环境中。我们需要将HTML文档传入Cheerio中。
这是首选的方法:
复制代码 代码如下:
var cheerio = require('cheerio'),
$ = cheerio.load('<ul id="fruits">...</ul>');
另外,您还可以将HTML作为字符串参数传入:
复制代码 代码如下:
$ = require('cheerio');
$('ul', '<ul id="fruits">...</ul>');
或者作为根结点
复制代码 代码如下:
$ = require('cheerio');
$('li', 'ul', '<ul id="fruits">...</ul>');
您也可以通过一个额外的.load()加载您需要修改的默认解析选项:
复制代码 代码如下:
$ = cheerio.load('<ul id="fruits">...</ul>', {
normalizeWhitespace: true,
xmlMode: true
});
这些解析选项是直接从 htmlparser2 借来的,因此可以在htmlparser2使用的任何参数在cheerio也有效。默认的选项是:
复制代码 代码如下:
{
normalizeWhitespace: false,
xmlMode: false,
decodeEntities: true
}
Selectors选择器
Cheerio的选择器几乎与jQuery的完全相同,所以API是非常相似的。
复制代码 代码如下:
$( selector, [context], [root] )
选择器按照: 根[root,可选]->上下文[context,可选]->选择器 的顺序选择元素。选择器和上下文可以是一个字符串表达式,DOM元素,DOM元素数组。根通常document 是 HTML文档的根元素。
像jQuery一样,此选择方法会从起点遍历和操纵文档。它是从文档中选择的元素的主要方法,但不像jQuery那样构建CSSSelect库(Sizzle 选择器)。
复制代码 代码如下:
$('.apple', '#fruits').text()
//=> Apple
$('ul .pear').attr('class')
//=> pear
$('li[class=orange]').html()
//=> <li class="orange">Orange</li>
Attributes属性
获取和修改属性的方法。
.attr( name, value )
用于获取和设置属性的方法。仅获取匹配的第一个元素的属性值。如果设置属性的值设置为null,则删除该属性。您也可以像jQuery一样传入map和function。
复制代码 代码如下:
$('ul').attr('id')
//=> fruits
$('.apple').attr('id', 'favorite').html()
//=> <li class="apple" id="favorite">Apple</li>
.data( name, value )
用于获取和设置数据属性的方法。获取或设置仅用于匹配的第一个元素。
复制代码 代码如下:
$('<div data-apple-color="red"></div>').data()
//=> { appleColor: 'red' }
$('<div data-apple-color="red"></div>').data('data-apple-color')
//=> 'red'
var apple = $('.apple').data('kind', 'mac')
apple.data('kind')
//=> 'mac'
.val( [value] )
用于获取和设置input,select和textarea值的方法。注:支持map,function尚未添加。
复制代码 代码如下:
$('input[type="text"]').val()
//=> input_text
$('input[type="text"]').val('test').html()
//=> <input type="text" value="test"/>
更多API请参见官网
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。