这是我的代码:
var request = require('request'),
cheerio = require('cheerio'),
async = require('async');
function updateCars(){
function getReviews(body){
var $ = cheerio.load(body);
var year = $(this).find(".field-item").text();
}
async.series([
....
function(callback) {
request(site+path, function(err, resp, body){
if(!err && resp.statusCode == 200){
var $ = cheerio.load(body);
$(".views-row").each(getReviews(body));
}
});
}
]);
}
当我在节点控制台中运行它时,我得到以下错误:
SyntaxError: Malformed attribute selector: object global]
我该如何解决?
答案 0 :(得分:1)
错误......
SyntaxError:格式错误的属性选择器:object global]
实际上是现货。由于这里只发布了违规代码的片段,所以 这里发生的情况并不完全清楚,但它绝对是属性选择器中的文书错误 - 很可能就是这个......
<强>答案:强>
$('div[id^=foo_bar'); // <-- missing the closing ]
上面的例子是一个错误,你通常(或编码你正在抓取的网站的人)不会注意到因为jQuery通常会悄悄地处理这个错误......
证明jQuery处理它:
var fooBars = $('a[id^="foo_bar"'); //<-- missing closing ]
$('#results').append("See... jQuery don't care about your closing ']' -" + fooBars.length)
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<a id="foo_bar_1">1</a>
<a id="foo_bar_2">2</a>
<a id="foo_bar_3">3</a>
<a id="foo_bim_4">4</a>
<a id="foo_bar_5">5</a>
<div id="results"></div>
<强>解释强>
错误实际上是Sizzle从cheerio下方的某处向你大喊大叫。虽然jQuery正在使用纯JavaScript实现...
var fooBar = document.querySelectorAll('a[id="foo_bar"'); // <-- missing
alert(fooBar.length); // works!
Cheerio正在使用Sizzle,它不喜欢“malformed”属性(曾经是IE 7-9中的一个问题)......
像jQuery,[Cheerios]选择元素中的元素的主要方法 文档,但与jQuery不同,它建立在CSSSelect之上 库,实现了大多数Sizzle选择器。