Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mbalabash/puppeteer-autoscroll-down
Handle infinite scroll on websites by puppeteer
https://github.com/mbalabash/puppeteer-autoscroll-down
headless-chrome parsing puppeteer
Last synced: 2 months ago
JSON representation
Handle infinite scroll on websites by puppeteer
- Host: GitHub
- URL: https://github.com/mbalabash/puppeteer-autoscroll-down
- Owner: mbalabash
- License: mit
- Created: 2019-01-25T21:03:25.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-02-21T02:33:56.000Z (11 months ago)
- Last Synced: 2024-11-10T16:08:54.557Z (3 months ago)
- Topics: headless-chrome, parsing, puppeteer
- Language: HTML
- Homepage:
- Size: 704 KB
- Stars: 49
- Watchers: 3
- Forks: 11
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Handle infinite scroll on websites with puppeteer
Small puppeteer tool which makes your parsing experience a little bit better
## Usage
**`size` - Number of pixels to scroll on each step** `[default: 250]`
**`delay` - Delay in ms after each completed scroll step** `[default: 100]`
**`stepsLimit` - Max number of steps to scroll** `[default: null]`
```js
const puppeteer = require('puppeteer')
const { scrollPageToBottom } = require('puppeteer-autoscroll-down')const browser = await puppeteer.launch()
const page = await browser.newPage()
await page.goto('http://example.com')const lastPosition = await scrollPageToBottom(page, {
size: 500,
delay: 250
})await browser.close()
```### Async content loading
**You can use returned value with request/response hooks to handle async content loading**
```js
const puppeteer = require('puppeteer')
const { scrollPageToBottom } = require('puppeteer-autoscroll-down')const browser = await puppeteer.launch()
const page = await browser.newPage()
await page.goto('http://example.com')let isLoadingAvailable = true // Your condition-to-stop
while (isLoadingAvailable) {
await scrollPageToBottom(page, { size: 500 })
await page.waitForResponse(
response => response.url() === 'http://example.com' && response.status() === 200
)
isLoadingAvailable = false // Update your condition-to-stop value
}await browser.close()
```### Not only scroll to the bottom, but there is also function for scroll to the top
**`scrollPageToTop` supports same API as `scrollPageToBottom`**
```js
const puppeteer = require('puppeteer')
const { scrollPageToTop } = require('puppeteer-autoscroll-down')const browser = await puppeteer.launch()
const page = await browser.newPage()
await page.goto('http://example.com')const lastPosition = await scrollPageToTop(page, {
size: 500,
delay: 250
})await browser.close()
```## Install
```sh
npm i puppeteer-autoscroll-down
```or
```sh
yarn add puppeteer-autoscroll-down
```## License
MIT