使用 cheerio 替换属性值
Replace the attribute value using cheerio
以下代码用于替换所有<img>
标签的src
值。但是下面的代码并没有修改原来的文件。 $.html
打印原始文档而不是修改后的文档。
$ = cheerio.load(data);
$("img").each(function() {
var old_src=$(this).attr("src");
var new_src = "/my_cached_image?url=" + encodeURIComponent(old_src);
$(this).prop("src", new_src);
});
modified_data = $.html();
使用 .attr('src', new_src)
代替 .prop()
。
你有一个很小的错误,
"src" 在 img 中它是一个属性而不是 属性。
所以这段代码可以工作:
var cheerio = require("cheerio");
var data = "<img src='yahoo.com'/>"
$ = cheerio.load(data);
$("img").each(function() {
var old_src=$(this).attr("src");
var new_src = "/my_cached_image?url=" + encodeURIComponent(old_src);
console.log(new_src);
$(this).attr("src", new_src);
});
console.log($.html());
输出是
<img src="/my_cached_image?url=yahoo.com">
以下代码用于替换所有<img>
标签的src
值。但是下面的代码并没有修改原来的文件。 $.html
打印原始文档而不是修改后的文档。
$ = cheerio.load(data);
$("img").each(function() {
var old_src=$(this).attr("src");
var new_src = "/my_cached_image?url=" + encodeURIComponent(old_src);
$(this).prop("src", new_src);
});
modified_data = $.html();
使用 .attr('src', new_src)
代替 .prop()
。
你有一个很小的错误, "src" 在 img 中它是一个属性而不是 属性。
所以这段代码可以工作:
var cheerio = require("cheerio");
var data = "<img src='yahoo.com'/>"
$ = cheerio.load(data);
$("img").each(function() {
var old_src=$(this).attr("src");
var new_src = "/my_cached_image?url=" + encodeURIComponent(old_src);
console.log(new_src);
$(this).attr("src", new_src);
});
console.log($.html());
输出是
<img src="/my_cached_image?url=yahoo.com">