我正在使用Puppeteer尝试在加载所有图像之后获取网站的屏幕截图,但无法使其正常工作。

这是到目前为止我得到的代码,我使用https://www.digg.com作为示例网站:

const puppeteer = require('puppeteer');

(async () => {
    const browser = await puppeteer.launch();
    const page = await browser.newPage();
    await page.goto('https://www.digg.com/');

    await page.setViewport({width: 1640, height: 800});

    await page.evaluate(() => {
        return Promise.resolve(window.scrollTo(0,document.body.scrollHeight));
    });

    await page.waitFor(1000);

    await page.evaluate(() => {
        var images = document.querySelectorAll('img');

        function preLoad() {

            var promises = [];

            function loadImage(img) {
                return new Promise(function(resolve,reject) {
                    if (img.complete) {
                        resolve(img)
                    }
                    img.onload = function() {
                        resolve(img);
                    };
                    img.onerror = function(e) {
                        resolve(img);
                    };
                })
            }

            for (var i = 0; i < images.length; i++)
            {
                promises.push(loadImage(images[i]));
            }

            return Promise.all(promises);
        }

        return preLoad();
    });

    await page.screenshot({path: 'digg.png', fullPage: true});

    browser.close();
})();

最佳答案

有一个built-in option:

await page.goto('https://www.digg.com/', {"waitUntil" : "networkidle0"});



P.S.当然,如果您使用的是诸如Twitter之类的无尽滚动单页应用程序,那么它将无法正常工作。

关于javascript - puppeteer 等待所有图像加载然后截图,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46160929/

10-11 05:26