docs: various documentation updates (#12500)

This commit is contained in:
Alex Rudenko 2024-05-29 11:14:12 +02:00 committed by GitHub
parent 33beb50903
commit e2e13eb4f0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
27 changed files with 349 additions and 290 deletions

View File

@ -6,48 +6,49 @@
<img src="https://user-images.githubusercontent.com/10379601/29446482-04f7036a-841f-11e7-9872-91d1fc2ea683.png" height="200" align="right"/> <img src="https://user-images.githubusercontent.com/10379601/29446482-04f7036a-841f-11e7-9872-91d1fc2ea683.png" height="200" align="right"/>
> Puppeteer is a Node.js library which provides a high-level API to control > Puppeteer is a Node.js library which provides a high-level API to control
> Chrome/Chromium over the > Chrome or Firefox over the
> [DevTools Protocol](https://chromedevtools.github.io/devtools-protocol/). > [DevTools Protocol](https://chromedevtools.github.io/devtools-protocol/) or [WebDriver BiDi](https://pptr.dev/webdriver-bidi).
> Puppeteer runs in > Puppeteer runs in the headless (no visible UI) by default
> [headless](https://developer.chrome.com/docs/chromium/new-headless/) > but can be configured to run in a visible ("headful") browser.
> mode by default, but can be configured to run in full ("headful")
> Chrome/Chromium.
## [Get started](https://pptr.dev/docs) | [API](https://pptr.dev/api) | [FAQ](https://pptr.dev/faq) | [Contributing](https://pptr.dev/contributing) | [Troubleshooting](https://pptr.dev/troubleshooting) ## [Get started](https://pptr.dev/docs) | [API](https://pptr.dev/api) | [FAQ](https://pptr.dev/faq) | [Contributing](https://pptr.dev/contributing) | [Troubleshooting](https://pptr.dev/troubleshooting)
## Installation
```bash npm2yarn
npm i puppeteer # Downloads compatible Chrome during installation.
npm i puppeteer-core # Alternatively, install as a library, without downloading Chrome.
```
## Example ## Example
```ts ```ts
import puppeteer from 'puppeteer'; import puppeteer from 'puppeteer'; // or import puppeteer from 'puppeteer-core';
(async () => {
// Launch the browser and open a new blank page // Launch the browser and open a new blank page
const browser = await puppeteer.launch(); const browser = await puppeteer.launch();
const page = await browser.newPage(); const page = await browser.newPage();
// Navigate the page to a URL // Navigate the page to a URL.
await page.goto('https://developer.chrome.com/'); await page.goto('https://developer.chrome.com/');
// Set screen size // Set screen size.
await page.setViewport({width: 1080, height: 1024}); await page.setViewport({width: 1080, height: 1024});
// Type into search box // Type into search box.
await page.type('.devsite-search-field', 'automate beyond recorder'); await page.type('.devsite-search-field', 'automate beyond recorder');
// Wait and click on first result // Wait and click on first result.
const searchResultSelector = '.devsite-result-item-link'; const searchResultSelector = '.devsite-result-item-link';
await page.waitForSelector(searchResultSelector); await page.waitForSelector(searchResultSelector);
await page.click(searchResultSelector); await page.click(searchResultSelector);
// Locate the full title with a unique string // Locate the full title with a unique string.
const textSelector = await page.waitForSelector( const textSelector = await page.waitForSelector('text/Customize and automate');
'text/Customize and automate'
);
const fullTitle = await textSelector?.evaluate(el => el.textContent); const fullTitle = await textSelector?.evaluate(el => el.textContent);
// Print the full title // Print the full title.
console.log('The title of this blog post is "%s".', fullTitle); console.log('The title of this blog post is "%s".', fullTitle);
await browser.close(); await browser.close();
})();
``` ```

View File

@ -1063,6 +1063,8 @@ Generic launch options that can be passed when launching any browser.
</td><td> </td><td>
A media feature to emulate.
</td></tr> </td></tr>
<tr><td> <tr><td>

View File

@ -41,7 +41,7 @@ Selector
</td><td> </td><td>
The selector to query for. [selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
</tbody></table> </tbody></table>

View File

@ -41,7 +41,7 @@ Selector
</td><td> </td><td>
The selector to query for. [selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
</tbody></table> </tbody></table>

View File

@ -52,7 +52,7 @@ Selector
</td><td> </td><td>
The selector to query for. [selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
<tr><td> <tr><td>

View File

@ -52,7 +52,7 @@ Selector
</td><td> </td><td>
The selector to query for. [selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
<tr><td> <tr><td>

View File

@ -4,7 +4,7 @@ sidebar_label: Frame.goto
# Frame.goto() method # Frame.goto() method
Navigates the frame to the given `url`. Navigates the frame or page to the given `url`.
#### Signature: #### Signature:
@ -69,9 +69,15 @@ A promise which resolves to the main resource response. In case of multiple redi
If: If:
- there's an SSL error (e.g. in case of self-signed certificates). - target URL is invalid. - the timeout is exceeded during navigation. - the remote server does not respond or is unreachable. - the main resource failed to load. - there's an SSL error (e.g. in case of self-signed certificates).
This method will not throw an error when any valid HTTP status code is returned by the remote server, including 404 "Not Found" and 500 "Internal Server Error". The status code for such responses can be retrieved by calling [HTTPResponse.status()](./puppeteer.httpresponse.status.md). - target URL is invalid.
- the timeout is exceeded during navigation.
- the remote server does not respond or is unreachable.
- the main resource failed to load.
## Remarks ## Remarks
@ -79,6 +85,8 @@ Navigation to `about:blank` or navigation to the same URL with a different hash
:::warning :::warning
Headless mode doesn't support navigation to a PDF document. See the [upstream issue](https://bugs.chromium.org/p/chromium/issues/detail?id=761295). Headless shell mode doesn't support navigation to a PDF document. See the [upstream issue](https://crbug.com/761295).
::: :::
In headless shell, this method will not throw an error when any valid HTTP status code is returned by the remote server, including 404 "Not Found" and 500 "Internal Server Error". The status code for such responses can be retrieved by calling [HTTPResponse.status()](./puppeteer.httpresponse.status.md).

View File

@ -4,6 +4,10 @@ sidebar_label: Frame.isOOPFrame
# Frame.isOOPFrame() method # Frame.isOOPFrame() method
> Warning: This API is now obsolete.
>
> Generally, there should be no difference between local and out-of-process frames from the Puppeteer API perspective. This is an implementation detail that should not have been exposed.
Is `true` if the frame is an out-of-process (OOP) frame. Otherwise, `false`. Is `true` if the frame is an out-of-process (OOP) frame. Otherwise, `false`.
#### Signature: #### Signature:

View File

@ -287,7 +287,7 @@ Focuses the first element that matches the `selector`.
</td><td> </td><td>
Navigates the frame to the given `url`. Navigates the frame or page to the given `url`.
**Remarks:** **Remarks:**
@ -295,10 +295,12 @@ Navigation to `about:blank` or navigation to the same URL with a different hash
:::warning :::warning
Headless mode doesn't support navigation to a PDF document. See the [upstream issue](https://bugs.chromium.org/p/chromium/issues/detail?id=761295). Headless shell mode doesn't support navigation to a PDF document. See the [upstream issue](https://crbug.com/761295).
::: :::
In headless shell, this method will not throw an error when any valid HTTP status code is returned by the remote server, including 404 "Not Found" and 500 "Internal Server Error". The status code for such responses can be retrieved by calling [HTTPResponse.status()](./puppeteer.httpresponse.status.md).
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -334,10 +336,16 @@ Use the `detached` getter.
</td><td> </td><td>
`deprecated`
</td><td> </td><td>
Is `true` if the frame is an out-of-process (OOP) frame. Otherwise, `false`. Is `true` if the frame is an out-of-process (OOP) frame. Otherwise, `false`.
**Deprecated:**
Generally, there should be no difference between local and out-of-process frames from the Puppeteer API perspective. This is an implementation detail that should not have been exposed.
</td></tr> </td></tr>
<tr><td> <tr><td>

View File

@ -4,6 +4,8 @@ sidebar_label: MediaFeature
# MediaFeature interface # MediaFeature interface
A media feature to emulate.
#### Signature: #### Signature:
```typescript ```typescript
@ -45,6 +47,8 @@ string
</td><td> </td><td>
A name of the feature, for example, 'prefers-reduced-motion'.
</td><td> </td><td>
</td></tr> </td></tr>
@ -60,6 +64,8 @@ string
</td><td> </td><td>
A value for the feature, for example, 'reduce'.
</td><td> </td><td>
</td></tr> </td></tr>

View File

@ -4,7 +4,7 @@ sidebar_label: Page.$
# Page.$() method # Page.$() method
Runs `document.querySelector` within the page. If no element matches the selector, the return value resolves to `null`. Finds the first element that matches the selector. If no element matches the selector, the return value resolves to `null`.
#### Signature: #### Signature:
@ -41,10 +41,14 @@ Selector
</td><td> </td><td>
A `selector` to query page for [selector](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) to query page for. [selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
</tbody></table> </tbody></table>
**Returns:** **Returns:**
Promise&lt;[ElementHandle](./puppeteer.elementhandle.md)&lt;[NodeFor](./puppeteer.nodefor.md)&lt;Selector&gt;&gt; \| null&gt; Promise&lt;[ElementHandle](./puppeteer.elementhandle.md)&lt;[NodeFor](./puppeteer.nodefor.md)&lt;Selector&gt;&gt; \| null&gt;
## Remarks
Shortcut for [Page.mainFrame().$(selector)](./puppeteer.frame._.md).

View File

@ -4,7 +4,7 @@ sidebar_label: Page.$$
# Page.$$() method # Page.$$() method
The method runs `document.querySelectorAll` within the page. If no elements match the selector, the return value resolves to `[]`. Finds elements on the page that match the selector. If no elements match the selector, the return value resolves to `[]`.
#### Signature: #### Signature:
@ -41,7 +41,7 @@ Selector
</td><td> </td><td>
A `selector` to query page for [selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
</tbody></table> </tbody></table>

View File

@ -4,7 +4,7 @@ sidebar_label: Page.$$eval
# Page.$$eval() method # Page.$$eval() method
This method runs `Array.from(document.querySelectorAll(selector))` within the page and passes the result as the first argument to the `pageFunction`. This method returns all elements matching the selector and passes the resulting array as the first argument to the `pageFunction`.
#### Signature: #### Signature:
@ -50,7 +50,7 @@ Selector
</td><td> </td><td>
the [selector](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) to query for [selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -63,7 +63,7 @@ Func \| string
</td><td> </td><td>
the function to be evaluated in the page context. Will be passed the result of `Array.from(document.querySelectorAll(selector))` as its first argument. the function to be evaluated in the page context. Will be passed an array of matching elements as its first argument.
</td></tr> </td></tr>
<tr><td> <tr><td>

View File

@ -4,7 +4,7 @@ sidebar_label: Page.$eval
# Page.$eval() method # Page.$eval() method
This method runs `document.querySelector` within the page and passes the result as the first argument to the `pageFunction`. This method finds the first element within the page that matches the selector and passes the result as the first argument to the `pageFunction`.
#### Signature: #### Signature:
@ -50,7 +50,7 @@ Selector
</td><td> </td><td>
the [selector](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) to query for [selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -63,7 +63,7 @@ Func \| string
</td><td> </td><td>
the function to be evaluated in the page context. Will be passed the result of `document.querySelector(selector)` as its first argument. the function to be evaluated in the page context. Will be passed the result of the element matching the selector as its first argument.
</td></tr> </td></tr>
<tr><td> <tr><td>

View File

@ -6,6 +6,12 @@ sidebar_label: Page.authenticate
Provide credentials for `HTTP authentication`. Provide credentials for `HTTP authentication`.
:::note
Request interception will be turned on behind the scenes to implement authentication. This might affect performance.
:::
#### Signature: #### Signature:
```typescript ```typescript

View File

@ -48,11 +48,3 @@ _(Optional)_ Navigation parameters
Promise&lt;[HTTPResponse](./puppeteer.httpresponse.md) \| null&gt; Promise&lt;[HTTPResponse](./puppeteer.httpresponse.md) \| null&gt;
Promise which resolves to the main resource response. In case of multiple redirects, the navigation will resolve with the response of the last redirect. If can not go back, resolves to `null`. Promise which resolves to the main resource response. In case of multiple redirects, the navigation will resolve with the response of the last redirect. If can not go back, resolves to `null`.
## Remarks
The argument `options` might have the following properties:
- `timeout` : Maximum navigation time in milliseconds, defaults to 30 seconds, pass 0 to disable timeout. The default value can be changed by using the [Page.setDefaultNavigationTimeout()](./puppeteer.page.setdefaultnavigationtimeout.md) or [Page.setDefaultTimeout()](./puppeteer.page.setdefaulttimeout.md) methods.
- `waitUntil` : When to consider navigation succeeded, defaults to `load`. Given an array of event strings, navigation is considered to be successful after all events have been fired. Events can be either:<br/> - `load` : consider navigation to be finished when the load event is fired.<br/> - `domcontentloaded` : consider navigation to be finished when the DOMContentLoaded event is fired.<br/> - `networkidle0` : consider navigation to be finished when there are no more than 0 network connections for at least `500` ms.<br/> - `networkidle2` : consider navigation to be finished when there are no more than 2 network connections for at least `500` ms.

View File

@ -48,11 +48,3 @@ _(Optional)_ Navigation Parameter
Promise&lt;[HTTPResponse](./puppeteer.httpresponse.md) \| null&gt; Promise&lt;[HTTPResponse](./puppeteer.httpresponse.md) \| null&gt;
Promise which resolves to the main resource response. In case of multiple redirects, the navigation will resolve with the response of the last redirect. If can not go forward, resolves to `null`. Promise which resolves to the main resource response. In case of multiple redirects, the navigation will resolve with the response of the last redirect. If can not go forward, resolves to `null`.
## Remarks
The argument `options` might have the following properties:
- `timeout` : Maximum navigation time in milliseconds, defaults to 30 seconds, pass 0 to disable timeout. The default value can be changed by using the [Page.setDefaultNavigationTimeout()](./puppeteer.page.setdefaultnavigationtimeout.md) or [Page.setDefaultTimeout()](./puppeteer.page.setdefaulttimeout.md) methods.
- `waitUntil`: When to consider navigation succeeded, defaults to `load`. Given an array of event strings, navigation is considered to be successful after all events have been fired. Events can be either:<br/> - `load` : consider navigation to be finished when the load event is fired.<br/> - `domcontentloaded` : consider navigation to be finished when the DOMContentLoaded event is fired.<br/> - `networkidle0` : consider navigation to be finished when there are no more than 0 network connections for at least `500` ms.<br/> - `networkidle2` : consider navigation to be finished when there are no more than 2 network connections for at least `500` ms.

View File

@ -4,7 +4,7 @@ sidebar_label: Page.goto
# Page.goto() method # Page.goto() method
Navigates the page to the given `url`. Navigates the frame or page to the given `url`.
#### Signature: #### Signature:
@ -39,7 +39,7 @@ string
</td><td> </td><td>
URL to navigate page to. The URL should include scheme, e.g. `https://` URL to navigate the frame to. The URL should include scheme, e.g. `https://`
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -62,22 +62,14 @@ Promise&lt;[HTTPResponse](./puppeteer.httpresponse.md) \| null&gt;
A promise which resolves to the main resource response. In case of multiple redirects, the navigation will resolve with the response of the last redirect. A promise which resolves to the main resource response. In case of multiple redirects, the navigation will resolve with the response of the last redirect.
## Exceptions
If:
- there's an SSL error (e.g. in case of self-signed certificates). - target URL is invalid. - the timeout is exceeded during navigation. - the remote server does not respond or is unreachable. - the main resource failed to load.
This method will not throw an error when any valid HTTP status code is returned by the remote server, including 404 "Not Found" and 500 "Internal Server Error". The status code for such responses can be retrieved by calling [HTTPResponse.status()](./puppeteer.httpresponse.status.md).
## Remarks ## Remarks
Navigation to `about:blank` or navigation to the same URL with a different hash will succeed and return `null`. Navigation to `about:blank` or navigation to the same URL with a different hash will succeed and return `null`.
:::warning :::warning
Headless mode doesn't support navigation to a PDF document. See the [upstream issue](https://bugs.chromium.org/p/chromium/issues/detail?id=761295). Headless shell mode doesn't support navigation to a PDF document. See the [upstream issue](https://crbug.com/761295).
::: :::
Shortcut for [page.mainFrame().goto(url, options)](./puppeteer.frame.goto.md). In headless shell, this method will not throw an error when any valid HTTP status code is returned by the remote server, including 404 "Not Found" and 500 "Internal Server Error". The status code for such responses can be retrieved by calling [HTTPResponse.status()](./puppeteer.httpresponse.status.md).

View File

@ -41,6 +41,8 @@ Selector
</td><td> </td><td>
[selector](https://pptr.dev/guides/page-interactions#query-selectors) to query page for. [CSS selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors) can be passed as-is and a [Puppeteer-specific seletor syntax](https://pptr.dev/guides/page-interactions#p-selectors) allows quering by [text](https://pptr.dev/guides/page-interactions#text-selectors--p-text), [a11y role and name](https://pptr.dev/guides/page-interactions#aria-selectors--p-aria), and [xpath](https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath) and [combining these queries across shadow roots](https://pptr.dev/guides/page-interactions#-and--combinators). Alternatively, you can specify a selector type using a prefix [prefix](https://pptr.dev/guides/page-interactions#built-in-selectors).
</td></tr> </td></tr>
</tbody></table> </tbody></table>
**Returns:** **Returns:**

View File

@ -17,7 +17,3 @@ class Page {
**Returns:** **Returns:**
[Frame](./puppeteer.frame.md) [Frame](./puppeteer.frame.md)
## Remarks
Page is guaranteed to have a main frame which persists during navigations.

View File

@ -241,7 +241,11 @@ Description
</td><td> </td><td>
Runs `document.querySelector` within the page. If no element matches the selector, the return value resolves to `null`. Finds the first element that matches the selector. If no element matches the selector, the return value resolves to `null`.
**Remarks:**
Shortcut for [Page.mainFrame().$(selector)](./puppeteer.frame._.md).
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -252,7 +256,7 @@ Runs `document.querySelector` within the page. If no element matches the selecto
</td><td> </td><td>
The method runs `document.querySelectorAll` within the page. If no elements match the selector, the return value resolves to `[]`. Finds elements on the page that match the selector. If no elements match the selector, the return value resolves to `[]`.
**Remarks:** **Remarks:**
@ -267,7 +271,7 @@ Shortcut for [Page.mainFrame().$$(selector)](./puppeteer.frame.__.md).
</td><td> </td><td>
This method runs `Array.from(document.querySelectorAll(selector))` within the page and passes the result as the first argument to the `pageFunction`. This method returns all elements matching the selector and passes the resulting array as the first argument to the `pageFunction`.
**Remarks:** **Remarks:**
@ -282,7 +286,7 @@ If `pageFunction` returns a promise `$$eval` will wait for the promise to resolv
</td><td> </td><td>
This method runs `document.querySelector` within the page and passes the result as the first argument to the `pageFunction`. This method finds the first element within the page that matches the selector and passes the result as the first argument to the `pageFunction`.
**Remarks:** **Remarks:**
@ -338,6 +342,12 @@ Shortcut for [page.mainFrame().addStyleTag(options)](./puppeteer.frame.addstylet
Provide credentials for `HTTP authentication`. Provide credentials for `HTTP authentication`.
:::note
Request interception will be turned on behind the scenes to implement authentication. This might affect performance.
:::
**Remarks:** **Remarks:**
To disable authentication, pass `null`. To disable authentication, pass `null`.
@ -673,14 +683,6 @@ Maximum time in milliseconds.
This method navigate to the previous page in history. This method navigate to the previous page in history.
**Remarks:**
The argument `options` might have the following properties:
- `timeout` : Maximum navigation time in milliseconds, defaults to 30 seconds, pass 0 to disable timeout. The default value can be changed by using the [Page.setDefaultNavigationTimeout()](./puppeteer.page.setdefaultnavigationtimeout.md) or [Page.setDefaultTimeout()](./puppeteer.page.setdefaulttimeout.md) methods.
- `waitUntil` : When to consider navigation succeeded, defaults to `load`. Given an array of event strings, navigation is considered to be successful after all events have been fired. Events can be either:<br/> - `load` : consider navigation to be finished when the load event is fired.<br/> - `domcontentloaded` : consider navigation to be finished when the DOMContentLoaded event is fired.<br/> - `networkidle0` : consider navigation to be finished when there are no more than 0 network connections for at least `500` ms.<br/> - `networkidle2` : consider navigation to be finished when there are no more than 2 network connections for at least `500` ms.
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -692,14 +694,6 @@ The argument `options` might have the following properties:
This method navigate to the next page in history. This method navigate to the next page in history.
**Remarks:**
The argument `options` might have the following properties:
- `timeout` : Maximum navigation time in milliseconds, defaults to 30 seconds, pass 0 to disable timeout. The default value can be changed by using the [Page.setDefaultNavigationTimeout()](./puppeteer.page.setdefaultnavigationtimeout.md) or [Page.setDefaultTimeout()](./puppeteer.page.setdefaulttimeout.md) methods.
- `waitUntil`: When to consider navigation succeeded, defaults to `load`. Given an array of event strings, navigation is considered to be successful after all events have been fired. Events can be either:<br/> - `load` : consider navigation to be finished when the load event is fired.<br/> - `domcontentloaded` : consider navigation to be finished when the DOMContentLoaded event is fired.<br/> - `networkidle0` : consider navigation to be finished when there are no more than 0 network connections for at least `500` ms.<br/> - `networkidle2` : consider navigation to be finished when there are no more than 2 network connections for at least `500` ms.
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -709,7 +703,7 @@ The argument `options` might have the following properties:
</td><td> </td><td>
Navigates the page to the given `url`. Navigates the frame or page to the given `url`.
**Remarks:** **Remarks:**
@ -717,11 +711,11 @@ Navigation to `about:blank` or navigation to the same URL with a different hash
:::warning :::warning
Headless mode doesn't support navigation to a PDF document. See the [upstream issue](https://bugs.chromium.org/p/chromium/issues/detail?id=761295). Headless shell mode doesn't support navigation to a PDF document. See the [upstream issue](https://crbug.com/761295).
::: :::
Shortcut for [page.mainFrame().goto(url, options)](./puppeteer.frame.goto.md). In headless shell, this method will not throw an error when any valid HTTP status code is returned by the remote server, including 404 "Not Found" and 500 "Internal Server Error". The status code for such responses can be retrieved by calling [HTTPResponse.status()](./puppeteer.httpresponse.status.md).
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -829,10 +823,6 @@ Locators API is experimental and we will not follow semver for breaking change i
The page's main frame. The page's main frame.
**Remarks:**
Page is guaranteed to have a main frame which persists during navigations.
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -1009,14 +999,6 @@ Toggles ignoring cache for each request based on the enabled state. By default,
Set the content of the page. Set the content of the page.
**Remarks:**
The parameter `options` might have the following options.
- `timeout` : Maximum time in milliseconds for resources to load, defaults to 30 seconds, pass `0` to disable timeout. The default value can be changed by using the [Page.setDefaultNavigationTimeout()](./puppeteer.page.setdefaultnavigationtimeout.md) or [Page.setDefaultTimeout()](./puppeteer.page.setdefaulttimeout.md) methods.
- `waitUntil`: When to consider setting markup succeeded, defaults to `load`. Given an array of event strings, setting content is considered to be successful after all events have been fired. Events can be either:<br/> - `load` : consider setting content to be finished when the `load` event is fired.<br/> - `domcontentloaded` : consider setting content to be finished when the `DOMContentLoaded` event is fired.<br/> - `networkidle0` : consider setting content to be finished when there are no more than 0 network connections for at least `500` ms.<br/> - `networkidle2` : consider setting content to be finished when there are no more than 2 network connections for at least `500` ms.
</td></tr> </td></tr>
<tr><td> <tr><td>
@ -1300,6 +1282,12 @@ This must be called before the file chooser is launched. It will not return a cu
::: :::
:::caution
Interception of file dialogs triggered via DOM APIs such as window.showOpenFilePicker is currently not supported.
:::
**Remarks:** **Remarks:**
In the "headful" browser, this method results in the native file picker dialog `not showing up` for the user. In the "headful" browser, this method results in the native file picker dialog `not showing up` for the user.

View File

@ -59,11 +59,3 @@ _(Optional)_ Parameters that has some properties.
**Returns:** **Returns:**
Promise&lt;void&gt; Promise&lt;void&gt;
## Remarks
The parameter `options` might have the following options.
- `timeout` : Maximum time in milliseconds for resources to load, defaults to 30 seconds, pass `0` to disable timeout. The default value can be changed by using the [Page.setDefaultNavigationTimeout()](./puppeteer.page.setdefaultnavigationtimeout.md) or [Page.setDefaultTimeout()](./puppeteer.page.setdefaulttimeout.md) methods.
- `waitUntil`: When to consider setting markup succeeded, defaults to `load`. Given an array of event strings, setting content is considered to be successful after all events have been fired. Events can be either:<br/> - `load` : consider setting content to be finished when the `load` event is fired.<br/> - `domcontentloaded` : consider setting content to be finished when the `DOMContentLoaded` event is fired.<br/> - `networkidle0` : consider setting content to be finished when there are no more than 0 network connections for at least `500` ms.<br/> - `networkidle2` : consider setting content to be finished when there are no more than 2 network connections for at least `500` ms.

View File

@ -12,6 +12,12 @@ This must be called before the file chooser is launched. It will not return a cu
::: :::
:::caution
Interception of file dialogs triggered via DOM APIs such as window.showOpenFilePicker is currently not supported.
:::
#### Signature: #### Signature:
```typescript ```typescript

View File

@ -10,48 +10,49 @@ hide_table_of_contents: true
<img src="https://user-images.githubusercontent.com/10379601/29446482-04f7036a-841f-11e7-9872-91d1fc2ea683.png" height="200" align="right"/> <img src="https://user-images.githubusercontent.com/10379601/29446482-04f7036a-841f-11e7-9872-91d1fc2ea683.png" height="200" align="right"/>
> Puppeteer is a Node.js library which provides a high-level API to control > Puppeteer is a Node.js library which provides a high-level API to control
> Chrome/Chromium over the > Chrome or Firefox over the
> [DevTools Protocol](https://chromedevtools.github.io/devtools-protocol/). > [DevTools Protocol](https://chromedevtools.github.io/devtools-protocol/) or [WebDriver BiDi](https://pptr.dev/webdriver-bidi).
> Puppeteer runs in > Puppeteer runs in the headless (no visible UI) by default
> [headless](https://developer.chrome.com/docs/chromium/new-headless/) > but can be configured to run in a visible ("headful") browser.
> mode by default, but can be configured to run in full ("headful")
> Chrome/Chromium.
## [Get started](https://pptr.dev/docs) | [API](https://pptr.dev/api) | [FAQ](https://pptr.dev/faq) | [Contributing](https://pptr.dev/contributing) | [Troubleshooting](https://pptr.dev/troubleshooting) ## [Get started](https://pptr.dev/docs) | [API](https://pptr.dev/api) | [FAQ](https://pptr.dev/faq) | [Contributing](https://pptr.dev/contributing) | [Troubleshooting](https://pptr.dev/troubleshooting)
## Installation
```bash npm2yarn
npm i puppeteer # Downloads compatible Chrome during installation.
npm i puppeteer-core # Alternatively, install as a library, without downloading Chrome.
```
## Example ## Example
```ts ```ts
import puppeteer from 'puppeteer'; import puppeteer from 'puppeteer'; // or import puppeteer from 'puppeteer-core';
(async () => {
// Launch the browser and open a new blank page // Launch the browser and open a new blank page
const browser = await puppeteer.launch(); const browser = await puppeteer.launch();
const page = await browser.newPage(); const page = await browser.newPage();
// Navigate the page to a URL // Navigate the page to a URL.
await page.goto('https://developer.chrome.com/'); await page.goto('https://developer.chrome.com/');
// Set screen size // Set screen size.
await page.setViewport({width: 1080, height: 1024}); await page.setViewport({width: 1080, height: 1024});
// Type into search box // Type into search box.
await page.type('.devsite-search-field', 'automate beyond recorder'); await page.type('.devsite-search-field', 'automate beyond recorder');
// Wait and click on first result // Wait and click on first result.
const searchResultSelector = '.devsite-result-item-link'; const searchResultSelector = '.devsite-result-item-link';
await page.waitForSelector(searchResultSelector); await page.waitForSelector(searchResultSelector);
await page.click(searchResultSelector); await page.click(searchResultSelector);
// Locate the full title with a unique string // Locate the full title with a unique string.
const textSelector = await page.waitForSelector( const textSelector = await page.waitForSelector('text/Customize and automate');
'text/Customize and automate'
);
const fullTitle = await textSelector?.evaluate(el => el.textContent); const fullTitle = await textSelector?.evaluate(el => el.textContent);
// Print the full title // Print the full title.
console.log('The title of this blog post is "%s".', fullTitle); console.log('The title of this blog post is "%s".', fullTitle);
await browser.close(); await browser.close();
})();
``` ```

View File

@ -122,7 +122,9 @@ This is an exciting step towards a more unified and efficient cross-browser auto
- HTTPRequest.isInterceptResolutionHandled() - HTTPRequest.isInterceptResolutionHandled()
- HTTPRequest.respond() - HTTPRequest.respond()
- HTTPRequest.responseForRequest() - HTTPRequest.responseForRequest()
- Page.authenticate()
- Page.setRequestInterception() - Page.setRequestInterception()
- Page.setUserAgent()
## Puppeteer features not yet supported over WebDriver BiDi ## Puppeteer features not yet supported over WebDriver BiDi
@ -160,7 +162,6 @@ This is an exciting step towards a more unified and efficient cross-browser auto
- Input.dragAndDrop() - Input.dragAndDrop()
- Input.dragOver() - Input.dragOver()
- Input.drop() - Input.drop()
- Page.authenticate()
- Page.emulateNetworkConditions() - Page.emulateNetworkConditions()
- Page.isDragInterceptionEnabled() - Page.isDragInterceptionEnabled()
- Page.isJavaScriptEnabled() (supported only in Chrome) - Page.isJavaScriptEnabled() (supported only in Chrome)
@ -171,7 +172,6 @@ This is an exciting step towards a more unified and efficient cross-browser auto
- Page.setBypassServiceWorker() - Page.setBypassServiceWorker()
- Page.setDragInterception() - Page.setDragInterception()
- Page.setOfflineMode() - Page.setOfflineMode()
- Page.setUserAgent()
- Page.waitForDevicePrompt() - Page.waitForDevicePrompt()
- Page.waitForFileChooser() - Page.waitForFileChooser()
- PageEvent.popup - PageEvent.popup

View File

@ -297,11 +297,15 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
/** /**
* Is `true` if the frame is an out-of-process (OOP) frame. Otherwise, * Is `true` if the frame is an out-of-process (OOP) frame. Otherwise,
* `false`. * `false`.
*
* @deprecated Generally, there should be no difference between local and
* out-of-process frames from the Puppeteer API perspective. This is an
* implementation detail that should not have been exposed.
*/ */
abstract isOOPFrame(): boolean; abstract isOOPFrame(): boolean;
/** /**
* Navigates the frame to the given `url`. * Navigates the frame or page to the given `url`.
* *
* @remarks * @remarks
* Navigation to `about:blank` or navigation to the same URL with a different * Navigation to `about:blank` or navigation to the same URL with a different
@ -309,12 +313,16 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
* *
* :::warning * :::warning
* *
* Headless mode doesn't support navigation to a PDF document. See the {@link * Headless shell mode doesn't support navigation to a PDF document. See the
* https://bugs.chromium.org/p/chromium/issues/detail?id=761295 | upstream * {@link https://crbug.com/761295 | upstream issue}.
* issue}.
* *
* ::: * :::
* *
* In headless shell, this method will not throw an error when any valid HTTP
* status code is returned by the remote server, including 404 "Not Found" and
* 500 "Internal Server Error". The status code for such responses can be
* retrieved by calling {@link HTTPResponse.status}.
*
* @param url - URL to navigate the frame to. The URL should include scheme, * @param url - URL to navigate the frame to. The URL should include scheme,
* e.g. `https://` * e.g. `https://`
* @param options - Options to configure waiting behavior. * @param options - Options to configure waiting behavior.
@ -324,15 +332,14 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
* @throws If: * @throws If:
* *
* - there's an SSL error (e.g. in case of self-signed certificates). * - there's an SSL error (e.g. in case of self-signed certificates).
* - target URL is invalid.
* - the timeout is exceeded during navigation.
* - the remote server does not respond or is unreachable.
* - the main resource failed to load.
* *
* This method will not throw an error when any valid HTTP status code is * - target URL is invalid.
* returned by the remote server, including 404 "Not Found" and 500 "Internal *
* Server Error". The status code for such responses can be retrieved by * - the timeout is exceeded during navigation.
* calling {@link HTTPResponse.status}. *
* - the remote server does not respond or is unreachable.
*
* - the main resource failed to load.
*/ */
abstract goto( abstract goto(
url: string, url: string,
@ -508,7 +515,22 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
/** /**
* Queries the frame for an element matching the given selector. * Queries the frame for an element matching the given selector.
* *
* @param selector - The selector to query for. * @param selector -
* {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
*
* @returns A {@link ElementHandle | element handle} to the first element * @returns A {@link ElementHandle | element handle} to the first element
* matching the given selector. Otherwise, `null`. * matching the given selector. Otherwise, `null`.
*/ */
@ -524,7 +546,22 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
/** /**
* Queries the frame for all elements matching the given selector. * Queries the frame for all elements matching the given selector.
* *
* @param selector - The selector to query for. * @param selector -
* {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
*
* @returns An array of {@link ElementHandle | element handles} that point to * @returns An array of {@link ElementHandle | element handles} that point to
* elements matching the given selector. * elements matching the given selector.
*/ */
@ -550,7 +587,21 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
* const searchValue = await frame.$eval('#search', el => el.value); * const searchValue = await frame.$eval('#search', el => el.value);
* ``` * ```
* *
* @param selector - The selector to query for. * @param selector -
* {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
* @param pageFunction - The function to be evaluated in the frame's context. * @param pageFunction - The function to be evaluated in the frame's context.
* The first element matching the selector will be passed to the function as * The first element matching the selector will be passed to the function as
* its first argument. * its first argument.
@ -589,7 +640,21 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
* const divsCounts = await frame.$$eval('div', divs => divs.length); * const divsCounts = await frame.$$eval('div', divs => divs.length);
* ``` * ```
* *
* @param selector - The selector to query for. * @param selector -
* {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
* @param pageFunction - The function to be evaluated in the frame's context. * @param pageFunction - The function to be evaluated in the frame's context.
* An array of elements matching the given selector will be passed to the * An array of elements matching the given selector will be passed to the
* function as its first argument. * function as its first argument.

View File

@ -223,10 +223,18 @@ export interface GeolocationOptions {
} }
/** /**
* A media feature to emulate.
*
* @public * @public
*/ */
export interface MediaFeature { export interface MediaFeature {
/**
* A name of the feature, for example, 'prefers-reduced-motion'.
*/
name: string; name: string;
/**
* A value for the feature, for example, 'reduce'.
*/
value: string; value: string;
} }
@ -727,6 +735,13 @@ export abstract class Page extends EventEmitter<PageEvents> {
* *
* ::: * :::
* *
* :::caution
*
* Interception of file dialogs triggered via DOM APIs such as
* window.showOpenFilePicker is currently not supported.
*
* :::
*
* @remarks * @remarks
* In the "headful" browser, this method results in the native file picker * In the "headful" browser, this method results in the native file picker
* dialog `not showing up` for the user. * dialog `not showing up` for the user.
@ -782,9 +797,6 @@ export abstract class Page extends EventEmitter<PageEvents> {
/** /**
* The page's main frame. * The page's main frame.
*
* @remarks
* Page is guaranteed to have a main frame which persists during navigations.
*/ */
abstract mainFrame(): Frame; abstract mainFrame(): Frame;
@ -960,6 +972,22 @@ export abstract class Page extends EventEmitter<PageEvents> {
* Creates a locator for the provided selector. See {@link Locator} for * Creates a locator for the provided selector. See {@link Locator} for
* details and supported actions. * details and supported actions.
* *
* @param selector -
* {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
*
* @remarks * @remarks
* Locators API is experimental and we will not follow semver for breaking * Locators API is experimental and we will not follow semver for breaking
* change in the Locators API. * change in the Locators API.
@ -999,12 +1027,28 @@ export abstract class Page extends EventEmitter<PageEvents> {
} }
/** /**
* Runs `document.querySelector` within the page. If no element matches the * Finds the first element that matches the selector. If no element matches
* selector, the return value resolves to `null`. * the selector, the return value resolves to `null`.
* *
* @param selector - A `selector` to query page for * @param selector -
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | selector} * {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query page for. * to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
*
* @remarks
*
* Shortcut for {@link Frame.$ | Page.mainFrame().$(selector) }.
*/ */
async $<Selector extends string>( async $<Selector extends string>(
selector: Selector selector: Selector
@ -1013,10 +1057,24 @@ export abstract class Page extends EventEmitter<PageEvents> {
} }
/** /**
* The method runs `document.querySelectorAll` within the page. If no elements * Finds elements on the page that match the selector. If no elements
* match the selector, the return value resolves to `[]`. * match the selector, the return value resolves to `[]`.
* *
* @param selector - A `selector` to query page for * @param selector -
* {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
* *
* @remarks * @remarks
* *
@ -1127,8 +1185,8 @@ export abstract class Page extends EventEmitter<PageEvents> {
): Promise<JSHandle<Prototype[]>>; ): Promise<JSHandle<Prototype[]>>;
/** /**
* This method runs `document.querySelector` within the page and passes the * This method finds the first element within the page that matches the selector
* result as the first argument to the `pageFunction`. * and passes the result as the first argument to the `pageFunction`.
* *
* @remarks * @remarks
* *
@ -1176,11 +1234,23 @@ export abstract class Page extends EventEmitter<PageEvents> {
* ); * );
* ``` * ```
* *
* @param selector - the * @param selector -
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | selector} * {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query for * to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
* @param pageFunction - the function to be evaluated in the page context. * @param pageFunction - the function to be evaluated in the page context.
* Will be passed the result of `document.querySelector(selector)` as its * Will be passed the result of the element matching the selector as its
* first argument. * first argument.
* @param args - any additional arguments to pass through to `pageFunction`. * @param args - any additional arguments to pass through to `pageFunction`.
* *
@ -1205,8 +1275,8 @@ export abstract class Page extends EventEmitter<PageEvents> {
} }
/** /**
* This method runs `Array.from(document.querySelectorAll(selector))` within * This method returns all elements matching the selector and passes the
* the page and passes the result as the first argument to the `pageFunction`. * resulting array as the first argument to the `pageFunction`.
* *
* @remarks * @remarks
* If `pageFunction` returns a promise `$$eval` will wait for the promise to * If `pageFunction` returns a promise `$$eval` will wait for the promise to
@ -1249,12 +1319,23 @@ export abstract class Page extends EventEmitter<PageEvents> {
* ); * );
* ``` * ```
* *
* @param selector - the * @param selector -
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | selector} * {@link https://pptr.dev/guides/page-interactions#query-selectors | selector}
* to query for * to query page for.
* {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors | CSS selectors}
* can be passed as-is and a
* {@link https://pptr.dev/guides/page-interactions#p-selectors | Puppeteer-specific seletor syntax}
* allows quering by
* {@link https://pptr.dev/guides/page-interactions#text-selectors--p-text | text},
* {@link https://pptr.dev/guides/page-interactions#aria-selectors--p-aria | a11y role and name},
* and
* {@link https://pptr.dev/guides/page-interactions#xpath-selectors--p-xpath | xpath}
* and
* {@link https://pptr.dev/guides/page-interactions#-and--combinators | combining these queries across shadow roots}.
* Alternatively, you can specify a selector type using a prefix
* {@link https://pptr.dev/guides/page-interactions#built-in-selectors | prefix}.
* @param pageFunction - the function to be evaluated in the page context. * @param pageFunction - the function to be evaluated in the page context.
* Will be passed the result of * Will be passed an array of matching elements as its first argument.
* `Array.from(document.querySelectorAll(selector))` as its first argument.
* @param args - any additional arguments to pass through to `pageFunction`. * @param args - any additional arguments to pass through to `pageFunction`.
* *
* @returns The result of calling `pageFunction`. If it returns an element it * @returns The result of calling `pageFunction`. If it returns an element it
@ -1417,6 +1498,13 @@ export abstract class Page extends EventEmitter<PageEvents> {
/** /**
* Provide credentials for `HTTP authentication`. * Provide credentials for `HTTP authentication`.
* *
* :::note
*
* Request interception will be turned on behind the scenes to
* implement authentication. This might affect performance.
*
* :::
*
* @remarks * @remarks
* To disable authentication, pass `null`. * To disable authentication, pass `null`.
*/ */
@ -1516,69 +1604,13 @@ export abstract class Page extends EventEmitter<PageEvents> {
* *
* @param html - HTML markup to assign to the page. * @param html - HTML markup to assign to the page.
* @param options - Parameters that has some properties. * @param options - Parameters that has some properties.
*
* @remarks
*
* The parameter `options` might have the following options.
*
* - `timeout` : Maximum time in milliseconds for resources to load, defaults
* to 30 seconds, pass `0` to disable timeout. The default value can be
* changed by using the {@link Page.setDefaultNavigationTimeout} or
* {@link Page.setDefaultTimeout} methods.
*
* - `waitUntil`: When to consider setting markup succeeded, defaults to
* `load`. Given an array of event strings, setting content is considered
* to be successful after all events have been fired. Events can be
* either:<br/>
* - `load` : consider setting content to be finished when the `load` event
* is fired.<br/>
* - `domcontentloaded` : consider setting content to be finished when the
* `DOMContentLoaded` event is fired.<br/>
* - `networkidle0` : consider setting content to be finished when there are
* no more than 0 network connections for at least `500` ms.<br/>
* - `networkidle2` : consider setting content to be finished when there are
* no more than 2 network connections for at least `500` ms.
*/ */
async setContent(html: string, options?: WaitForOptions): Promise<void> { async setContent(html: string, options?: WaitForOptions): Promise<void> {
await this.mainFrame().setContent(html, options); await this.mainFrame().setContent(html, options);
} }
/** /**
* Navigates the page to the given `url`. * {@inheritDoc Frame.goto}
*
* @remarks
*
* Navigation to `about:blank` or navigation to the same URL with a different
* hash will succeed and return `null`.
*
* :::warning
*
* Headless mode doesn't support navigation to a PDF document. See the {@link
* https://bugs.chromium.org/p/chromium/issues/detail?id=761295 | upstream
* issue}.
*
* :::
*
* Shortcut for {@link Frame.goto | page.mainFrame().goto(url, options)}.
*
* @param url - URL to navigate page to. The URL should include scheme, e.g.
* `https://`
* @param options - Options to configure waiting behavior.
* @returns A promise which resolves to the main resource response. In case of
* multiple redirects, the navigation will resolve with the response of the
* last redirect.
* @throws If:
*
* - there's an SSL error (e.g. in case of self-signed certificates).
* - target URL is invalid.
* - the timeout is exceeded during navigation.
* - the remote server does not respond or is unreachable.
* - the main resource failed to load.
*
* This method will not throw an error when any valid HTTP status code is
* returned by the remote server, including 404 "Not Found" and 500 "Internal
* Server Error". The status code for such responses can be retrieved by
* calling {@link HTTPResponse.status}.
*/ */
async goto(url: string, options?: GoToOptions): Promise<HTTPResponse | null> { async goto(url: string, options?: GoToOptions): Promise<HTTPResponse | null> {
return await this.mainFrame().goto(url, options); return await this.mainFrame().goto(url, options);
@ -1818,25 +1850,6 @@ export abstract class Page extends EventEmitter<PageEvents> {
* @returns Promise which resolves to the main resource response. In case of * @returns Promise which resolves to the main resource response. In case of
* multiple redirects, the navigation will resolve with the response of the * multiple redirects, the navigation will resolve with the response of the
* last redirect. If can not go back, resolves to `null`. * last redirect. If can not go back, resolves to `null`.
* @remarks
* The argument `options` might have the following properties:
*
* - `timeout` : Maximum navigation time in milliseconds, defaults to 30
* seconds, pass 0 to disable timeout. The default value can be changed by
* using the {@link Page.setDefaultNavigationTimeout} or
* {@link Page.setDefaultTimeout} methods.
*
* - `waitUntil` : When to consider navigation succeeded, defaults to `load`.
* Given an array of event strings, navigation is considered to be
* successful after all events have been fired. Events can be either:<br/>
* - `load` : consider navigation to be finished when the load event is
* fired.<br/>
* - `domcontentloaded` : consider navigation to be finished when the
* DOMContentLoaded event is fired.<br/>
* - `networkidle0` : consider navigation to be finished when there are no
* more than 0 network connections for at least `500` ms.<br/>
* - `networkidle2` : consider navigation to be finished when there are no
* more than 2 network connections for at least `500` ms.
*/ */
abstract goBack(options?: WaitForOptions): Promise<HTTPResponse | null>; abstract goBack(options?: WaitForOptions): Promise<HTTPResponse | null>;
@ -1846,25 +1859,6 @@ export abstract class Page extends EventEmitter<PageEvents> {
* @returns Promise which resolves to the main resource response. In case of * @returns Promise which resolves to the main resource response. In case of
* multiple redirects, the navigation will resolve with the response of the * multiple redirects, the navigation will resolve with the response of the
* last redirect. If can not go forward, resolves to `null`. * last redirect. If can not go forward, resolves to `null`.
* @remarks
* The argument `options` might have the following properties:
*
* - `timeout` : Maximum navigation time in milliseconds, defaults to 30
* seconds, pass 0 to disable timeout. The default value can be changed by
* using the {@link Page.setDefaultNavigationTimeout} or
* {@link Page.setDefaultTimeout} methods.
*
* - `waitUntil`: When to consider navigation succeeded, defaults to `load`.
* Given an array of event strings, navigation is considered to be
* successful after all events have been fired. Events can be either:<br/>
* - `load` : consider navigation to be finished when the load event is
* fired.<br/>
* - `domcontentloaded` : consider navigation to be finished when the
* DOMContentLoaded event is fired.<br/>
* - `networkidle0` : consider navigation to be finished when there are no
* more than 0 network connections for at least `500` ms.<br/>
* - `networkidle2` : consider navigation to be finished when there are no
* more than 2 network connections for at least `500` ms.
*/ */
abstract goForward(options?: WaitForOptions): Promise<HTTPResponse | null>; abstract goForward(options?: WaitForOptions): Promise<HTTPResponse | null>;