pageres-cli

Capture website screenshots

Github星跟踪图

pageres-cli Build Status

Capture screenshots of websites in various resolutions. A good way to make sure your websites are responsive. It's speedy and generates 100 screenshots from 10 different websites in just over a minute. It can also be used to render SVG images.

See pageres for the programmatic API and issues tracker.

Install

$ npm install --global pageres-cli

Note to Linux users: If you get a "No usable sandbox!" error, you need to enable system sandboxing.

Usage

Specify urls and screen resolutions as arguments. Order doesn't matter.

If no resolution is specified it will default to 1366x768 which is the most popular resolution.

pageres <url> <resolution>
pageres <resolution> <url>

# <url> can also be a local file path.
pageres <file> <resolution>

List multiple urls and resolutions for pageres to capture all combinations.

pageres <url> <resolution> ...

pageres https://sindresorhus.com 1024x768 1366x768 # 2 screenshots
pageres https://sindresorhus.com https://example.com 1024x768 # 2 screenshots
pageres https://sindresorhus.com https://example.com 1024x768 1366x768 # 4 screenshots

Group arguments with square brackets.

pageres [ <url> <resolution> ] [ <url> <resolution> ]
pageres [ <url> <resolution> ... ]

# Mix grouped and single arguments
pageres [ https://example.com 1024x768 1600x900 ] https://sindresorhus.com 1366x768

# Options defined inside a group will override the outer ones.
pageres [ https://example.com 1024x768 --no-crop ] https://sindresorhus.com 1366x768 --crop

Screenshots are saved in the current directory.

Examples

# Basic multi-url, multi-resolution usage
pageres https://sindresorhus.com https://example.com 1366x768 1600x900

# Override outer option within group
pageres [ https://example.com 1366x768 1600x900 --no-crop ] [ https://sindresorhus.com 1024x768 480x320 ] --crop

# Provide a custom filename template
pageres https://sindresorhus.com 1024x768 --filename='<%= date %> - <%= url %>'

# Capture a specific element
pageres https://example.com 1366x768 --selector='.page-header'

# Hide a specific element
pageres https://example.com 1366x768 --hide='.page-header'

# Capture a local file
pageres unicorn.html 1366x768

Options

--verbose, -v

Verbose output to see errors if you need to troubleshoot.

--crop, -c

Crop to the set height.

$ pageres https://sindresorhus.com 1024x768 --crop
--delay=<number>, -d

Delay screenshot capture.

$ pageres https://sindresorhus.com 1024x768 --delay=3
--filename=<template>

Custom filename.

$ pageres https://sindresorhus.com 1024x768 --filename='<%= date %> - <%= url %>'
--overwrite

Overwrite destination file if it exists. Defaults to appending (n) to the file name if --overwrite is not set.

$ pageres https://sindresorhus.com 1366x768 --overwrite
--selector=<element>

Capture DOM element.

$ pageres https://example.com 1366x768 --selector='.page-header'
--hide=<element>

Hide DOM element. Can be set multiple times.

$ pageres https://example.com 1366x768 --hide='.page-header'
--no-crop

Override a global crop option within a group.

$ pageres [ https://example.com 1366x768 --no-crop ] https://sindresorhus.com 1024x768 --crop
--css=<string>

Apply custom CSS to the webpage. Specify some CSS or the path to a CSS file.

$ pageres https://sindresorhus.com --css='body { background: red; }'
$ pageres https://sindresorhus.com --css='style.css'
--cookie=<cookie>

Browser cookie. Can be set multiple times.

$ pageres https://example.com --cookie='foo=bar'
--header=<header>

Custom HTTP request header. Can be set multiple times.

$ pageres https://example.com --header='Cache-Control: no-cache'
--username=<username>

Username for HTTP auth.

--password=<password>

Password for HTTP auth.

--scale=<number>

Scale webpage n of times.

--format=<string>

Image format. Either png (default) or jpg.

--user-agent=<string>

Custom user agent.

--transparent

Set background color to transparent instead of white if no background is set.

Config file

You can persist your commands into a file and run it whenever with eg. sh .pageres:

# .pageres
pageres [ https://sindresorhus.com 1000x1000 --crop ] [ https://example.com 500x500 ]
pageres [ https://google.com 1000x1000 --crop ] [ https://github.com 500x500 ]

主要指标

概览
名称与所有者sindresorhus/pageres-cli
主编程语言JavaScript
编程语言JavaScript (语言数: 1)
平台
许可证MIT License
所有者活动
创建于2015-06-21 13:22:33
推送于2025-02-05 12:16:13
最后一次提交
发布数14
最新版本名称v8.0.0 (发布于 2023-11-06 19:36:17)
第一版名称1.0.0 (发布于 2015-06-21 16:17:25)
用户参与
星数1.7k
关注者数38
派生数72
提交数218
已启用问题?
问题数0
打开的问题数0
拉请求数6
打开的拉请求数0
关闭的拉请求数4
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?