JSDOM в nodeJS: как мне вернуть измененный html?

Я пытаюсь манипулировать удаленным HTML и возвращать его обработанным. Я решил использовать JSDOM, но не могу понять, как вернуть измененный HTML. Любые идеи?

  jsdom.env({
        url: "http://www.cnn.com",
        scripts: ["http://code.jquery.com/jquery.js"],
        done: function (err, window) {
            var $ = window.$;
            console.log("HN Links");
            var src = $(".ghciTopStoryImage1 img").attr('src','http://lorempixel.com/396/220/');
            var headline = $(".blkbigheader span").html('header');
            var description = $(".blkbigheader").parent().find("p a:eq(0)").html('text');

           // not working....
            content =$(window.document).html();

        }
    });

person Guy    schedule 05.08.2015    source источник
comment
В чем-то подобном я использовал: window.document.querySelector( 'html' ).outerHTML чтобы получить весь документ.   -  person Sirko    schedule 05.08.2015


Ответы (2)


Из ознакомительного файла jsdom:

var JSDOM = require("jsdom").JSDOM;

var jsdom = new JSDOM("<!DOCTYPE html>hello");

jsdom.serialize() === "<!DOCTYPE html><html><head></head><body>hello</body></html>";
doc.documentElement.outerHTML === "<html><head></head><body>hello</body></html>";

Адаптация приведенного выше примера будет просто content = jsdom.serialize().

person Domenic    schedule 26.08.2015

иногда jQuery не является ответом

content = window.document.documentElement.outerHTML;
person Jaromanda X    schedule 05.08.2015
comment
это лишит тип документа - person Benny Powers; 04.02.2019
comment
легко добавить с помощью window.document.doctype - person Jaromanda X; 04.02.2019