因?yàn)榫W(wǎng)絡(luò)原因,國內(nèi)安裝 puppeteer
的時(shí)候會(huì)報(bào)網(wǎng)絡(luò)超時(shí)。這里使用 puppeteer-core
之后使用手動(dòng)下載的 Chrome
進(jìn)行操作。思路很簡(jiǎn)單,安裝一個(gè)不帶瀏覽器的 puppeteer
,再使用的時(shí)候?qū)g覽器地址指向一個(gè)可執(zhí)行的 Chrome
瀏覽器文件。
安裝
安裝 puppeteer-core
。
yarn add puppeteer-core
找到 puppeteer 中對(duì)應(yīng)的瀏覽器并下載
在 node_modules/puppeteer-core/lib/BrowserFetcher.js
中找到各平臺(tái) Chrome
下載地址。其中 %s
替換為 DEFAULT_DOWNLOAD_HOST
的值, %d
替換為版本號(hào)。
在 node_modules/puppeteer-core/packages.json
中找到版本號(hào)
替換后得到下載地址
https://storage.googleapis.com/chromium-browser-snapshots/Mac/579032/chrome-mac.zip
下載后解壓,放在項(xiàng)目目錄中,這里我放在 chrome 下。
使用
這樣就可以使用了。
使用代碼
const puppeteer = require('puppeteer-core');const path = require('path');(async () => { const browser = await puppeteer.launch({ // 這里注意路徑指向可執(zhí)行的瀏覽器。 // 各平臺(tái)路徑可以在 node_modules/puppeteer-core/lib/BrowserFetcher.js 中找到 // Mac 為 '下載文件解壓路徑/Chromium.app/Contents/MacOS/Chromium' // Linux 為 '下載文件解壓路徑/chrome' // Windows 為 '下載文件解壓路徑/chrome.exe' executablePath: path.resolve('./chrome/Chromium.app/Contents/MacOS/Chromium') }); const page = await browser.newPage(); await page.setViewport({ width: 375, height: 667, deviceScaleFactor: 1, isMobile: true }) await page.goto('https://marxjiao.com/'); await page.screenshot({path: 'marx-blog.png'}); await browser.close();})();
執(zhí)行文件
node index.js
執(zhí)行后可看到,圖片已經(jīng)截圖出來了
代碼地址:https://github.com/MarxJiao/puppeteer-test
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注