mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
refactor!: remove $x
and waitForXpath
(#11782)
This commit is contained in:
parent
1900fa9418
commit
53c9134809
@ -1,33 +0,0 @@
|
|||||||
---
|
|
||||||
sidebar_label: ElementHandle.$x
|
|
||||||
---
|
|
||||||
|
|
||||||
# ElementHandle.$x() method
|
|
||||||
|
|
||||||
> Warning: This API is now obsolete.
|
|
||||||
>
|
|
||||||
> Use [ElementHandle.$$()](./puppeteer.elementhandle.__.md) with the `xpath` prefix.
|
|
||||||
>
|
|
||||||
> Example: `await elementHandle.$$('xpath/' + xpathExpression)`
|
|
||||||
>
|
|
||||||
> The method evaluates the XPath expression relative to the elementHandle. If `xpath` starts with `//` instead of `.//`, the dot will be appended automatically.
|
|
||||||
>
|
|
||||||
> If there are no such elements, the method will resolve to an empty array.
|
|
||||||
|
|
||||||
#### Signature:
|
|
||||||
|
|
||||||
```typescript
|
|
||||||
class ElementHandle {
|
|
||||||
$x(expression: string): Promise<Array<ElementHandle<Node>>>;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Parameters
|
|
||||||
|
|
||||||
| Parameter | Type | Description |
|
|
||||||
| ---------- | ------ | -------------------------------------------------------------------------------------------- |
|
|
||||||
| expression | string | Expression to [evaluate](https://developer.mozilla.org/en-US/docs/Web/API/Document/evaluate) |
|
|
||||||
|
|
||||||
**Returns:**
|
|
||||||
|
|
||||||
Promise<Array<[ElementHandle](./puppeteer.elementhandle.md)<Node>>>
|
|
@ -53,7 +53,6 @@ The constructor for this class is marked as internal. Third-party code should no
|
|||||||
| [$$(selector)](./puppeteer.elementhandle.__.md) | | Queries the current element for all elements matching the given selector. |
|
| [$$(selector)](./puppeteer.elementhandle.__.md) | | Queries the current element for all elements matching the given selector. |
|
||||||
| [$$eval(selector, pageFunction, args)](./puppeteer.elementhandle.__eval.md) | | <p>Runs the given function on an array of elements matching the given selector in the current element.</p><p>If the given function returns a promise, then this method will wait till the promise resolves.</p> |
|
| [$$eval(selector, pageFunction, args)](./puppeteer.elementhandle.__eval.md) | | <p>Runs the given function on an array of elements matching the given selector in the current element.</p><p>If the given function returns a promise, then this method will wait till the promise resolves.</p> |
|
||||||
| [$eval(selector, pageFunction, args)](./puppeteer.elementhandle._eval.md) | | <p>Runs the given function on the first element matching the given selector in the current element.</p><p>If the given function returns a promise, then this method will wait till the promise resolves.</p> |
|
| [$eval(selector, pageFunction, args)](./puppeteer.elementhandle._eval.md) | | <p>Runs the given function on the first element matching the given selector in the current element.</p><p>If the given function returns a promise, then this method will wait till the promise resolves.</p> |
|
||||||
| [$x(expression)](./puppeteer.elementhandle._x.md) | | |
|
|
||||||
| [autofill(data)](./puppeteer.elementhandle.autofill.md) | | If the element is a form input, you can use [ElementHandle.autofill()](./puppeteer.elementhandle.autofill.md) to test if the form is compatible with the browser's autofill implementation. Throws an error if the form cannot be autofilled. |
|
| [autofill(data)](./puppeteer.elementhandle.autofill.md) | | If the element is a form input, you can use [ElementHandle.autofill()](./puppeteer.elementhandle.autofill.md) to test if the form is compatible with the browser's autofill implementation. Throws an error if the form cannot be autofilled. |
|
||||||
| [boundingBox()](./puppeteer.elementhandle.boundingbox.md) | | This method returns the bounding box of the element (relative to the main frame), or <code>null</code> if the element is [not part of the layout](https://drafts.csswg.org/css-display-4/#box-generation) (example: <code>display: none</code>). |
|
| [boundingBox()](./puppeteer.elementhandle.boundingbox.md) | | This method returns the bounding box of the element (relative to the main frame), or <code>null</code> if the element is [not part of the layout](https://drafts.csswg.org/css-display-4/#box-generation) (example: <code>display: none</code>). |
|
||||||
| [boxModel()](./puppeteer.elementhandle.boxmodel.md) | | This method returns boxes of the element, or <code>null</code> if the element is [not part of the layout](https://drafts.csswg.org/css-display-4/#box-generation) (example: <code>display: none</code>). |
|
| [boxModel()](./puppeteer.elementhandle.boxmodel.md) | | This method returns boxes of the element, or <code>null</code> if the element is [not part of the layout](https://drafts.csswg.org/css-display-4/#box-generation) (example: <code>display: none</code>). |
|
||||||
@ -85,4 +84,3 @@ The constructor for this class is marked as internal. Third-party code should no
|
|||||||
| [type(text, options)](./puppeteer.elementhandle.type.md) | | <p>Focuses the element, and then sends a <code>keydown</code>, <code>keypress</code>/<code>input</code>, and <code>keyup</code> event for each character in the text.</p><p>To press a special key, like <code>Control</code> or <code>ArrowDown</code>, use [ElementHandle.press()](./puppeteer.elementhandle.press.md).</p> |
|
| [type(text, options)](./puppeteer.elementhandle.type.md) | | <p>Focuses the element, and then sends a <code>keydown</code>, <code>keypress</code>/<code>input</code>, and <code>keyup</code> event for each character in the text.</p><p>To press a special key, like <code>Control</code> or <code>ArrowDown</code>, use [ElementHandle.press()](./puppeteer.elementhandle.press.md).</p> |
|
||||||
| [uploadFile(this, paths)](./puppeteer.elementhandle.uploadfile.md) | | Sets the value of an [input element](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) to the given file paths. |
|
| [uploadFile(this, paths)](./puppeteer.elementhandle.uploadfile.md) | | Sets the value of an [input element](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) to the given file paths. |
|
||||||
| [waitForSelector(selector, options)](./puppeteer.elementhandle.waitforselector.md) | | <p>Wait for an element matching the given selector to appear in the current element.</p><p>Unlike [Frame.waitForSelector()](./puppeteer.frame.waitforselector.md), this method does not work across navigations or if the element is detached from DOM.</p> |
|
| [waitForSelector(selector, options)](./puppeteer.elementhandle.waitforselector.md) | | <p>Wait for an element matching the given selector to appear in the current element.</p><p>Unlike [Frame.waitForSelector()](./puppeteer.frame.waitforselector.md), this method does not work across navigations or if the element is detached from DOM.</p> |
|
||||||
| [waitForXPath(xpath, options)](./puppeteer.elementhandle.waitforxpath.md) | | |
|
|
||||||
|
@ -1,79 +0,0 @@
|
|||||||
---
|
|
||||||
sidebar_label: ElementHandle.waitForXPath
|
|
||||||
---
|
|
||||||
|
|
||||||
# ElementHandle.waitForXPath() method
|
|
||||||
|
|
||||||
> Warning: This API is now obsolete.
|
|
||||||
>
|
|
||||||
> Use [ElementHandle.waitForSelector()](./puppeteer.elementhandle.waitforselector.md) with the `xpath` prefix.
|
|
||||||
>
|
|
||||||
> Example: `await elementHandle.waitForSelector('xpath/' + xpathExpression)`
|
|
||||||
>
|
|
||||||
> The method evaluates the XPath expression relative to the elementHandle.
|
|
||||||
>
|
|
||||||
> Wait for the `xpath` within the element. If at the moment of calling the method the `xpath` already exists, the method will return immediately. If the `xpath` doesn't appear after the `timeout` milliseconds of waiting, the function will throw.
|
|
||||||
>
|
|
||||||
> If `xpath` starts with `//` instead of `.//`, the dot will be appended automatically.
|
|
||||||
|
|
||||||
#### Signature:
|
|
||||||
|
|
||||||
```typescript
|
|
||||||
class ElementHandle {
|
|
||||||
waitForXPath(
|
|
||||||
xpath: string,
|
|
||||||
options?: {
|
|
||||||
visible?: boolean;
|
|
||||||
hidden?: boolean;
|
|
||||||
timeout?: number;
|
|
||||||
}
|
|
||||||
): Promise<ElementHandle<Node> | null>;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Parameters
|
|
||||||
|
|
||||||
| Parameter | Type | Description |
|
|
||||||
| --------- | -------------------------------------------------------------------- | --------------------------------------------------------------------------------------- |
|
|
||||||
| xpath | string | A [xpath](https://developer.mozilla.org/en-US/docs/Web/XPath) of an element to wait for |
|
|
||||||
| options | { visible?: boolean; hidden?: boolean; timeout?: number; } | _(Optional)_ Optional waiting parameters |
|
|
||||||
|
|
||||||
**Returns:**
|
|
||||||
|
|
||||||
Promise<[ElementHandle](./puppeteer.elementhandle.md)<Node> \| null>
|
|
||||||
|
|
||||||
Promise which resolves when element specified by xpath string is added to DOM. Resolves to `null` if waiting for `hidden: true` and xpath is not found in DOM, otherwise resolves to `ElementHandle`.
|
|
||||||
|
|
||||||
## Remarks
|
|
||||||
|
|
||||||
The optional Argument `options` have properties:
|
|
||||||
|
|
||||||
- `visible`: A boolean to wait for element to be present in DOM and to be visible, i.e. to not have `display: none` or `visibility: hidden` CSS properties. Defaults to `false`.
|
|
||||||
|
|
||||||
- `hidden`: A boolean wait for element to not be found in the DOM or to be hidden, i.e. have `display: none` or `visibility: hidden` CSS properties. Defaults to `false`.
|
|
||||||
|
|
||||||
- `timeout`: A number which is maximum time to wait for in milliseconds. Defaults to `30000` (30 seconds). Pass `0` to disable timeout. The default value can be changed by using the [Page.setDefaultTimeout()](./puppeteer.page.setdefaulttimeout.md) method.
|
|
||||||
|
|
||||||
## Example
|
|
||||||
|
|
||||||
This method works across navigation.
|
|
||||||
|
|
||||||
```ts
|
|
||||||
import puppeteer from 'puppeteer';
|
|
||||||
(async () => {
|
|
||||||
const browser = await puppeteer.launch();
|
|
||||||
const page = await browser.newPage();
|
|
||||||
let currentURL;
|
|
||||||
page
|
|
||||||
.waitForXPath('//img')
|
|
||||||
.then(() => console.log('First URL with image: ' + currentURL));
|
|
||||||
for (currentURL of [
|
|
||||||
'https://example.com',
|
|
||||||
'https://google.com',
|
|
||||||
'https://bbc.com',
|
|
||||||
]) {
|
|
||||||
await page.goto(currentURL);
|
|
||||||
}
|
|
||||||
await browser.close();
|
|
||||||
})();
|
|
||||||
```
|
|
@ -1,31 +0,0 @@
|
|||||||
---
|
|
||||||
sidebar_label: Frame.$x
|
|
||||||
---
|
|
||||||
|
|
||||||
# Frame.$x() method
|
|
||||||
|
|
||||||
> Warning: This API is now obsolete.
|
|
||||||
>
|
|
||||||
> Use [Frame.$$()](./puppeteer.frame.__.md) with the `xpath` prefix.
|
|
||||||
>
|
|
||||||
> Example: `await frame.$$('xpath/' + xpathExpression)`
|
|
||||||
>
|
|
||||||
> This method evaluates the given XPath expression and returns the results. If `xpath` starts with `//` instead of `.//`, the dot will be appended automatically.
|
|
||||||
|
|
||||||
#### Signature:
|
|
||||||
|
|
||||||
```typescript
|
|
||||||
class Frame {
|
|
||||||
$x(expression: string): Promise<Array<ElementHandle<Node>>>;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Parameters
|
|
||||||
|
|
||||||
| Parameter | Type | Description |
|
|
||||||
| ---------- | ------ | --------------------------------- |
|
|
||||||
| expression | string | the XPath expression to evaluate. |
|
|
||||||
|
|
||||||
**Returns:**
|
|
||||||
|
|
||||||
Promise<Array<[ElementHandle](./puppeteer.elementhandle.md)<Node>>>
|
|
@ -75,7 +75,6 @@ console.log(text);
|
|||||||
| [$$(selector)](./puppeteer.frame.__.md) | | Queries the frame for all elements matching the given selector. |
|
| [$$(selector)](./puppeteer.frame.__.md) | | Queries the frame for all elements matching the given selector. |
|
||||||
| [$$eval(selector, pageFunction, args)](./puppeteer.frame.__eval.md) | | <p>Runs the given function on an array of elements matching the given selector in the frame.</p><p>If the given function returns a promise, then this method will wait till the promise resolves.</p> |
|
| [$$eval(selector, pageFunction, args)](./puppeteer.frame.__eval.md) | | <p>Runs the given function on an array of elements matching the given selector in the frame.</p><p>If the given function returns a promise, then this method will wait till the promise resolves.</p> |
|
||||||
| [$eval(selector, pageFunction, args)](./puppeteer.frame._eval.md) | | <p>Runs the given function on the first element matching the given selector in the frame.</p><p>If the given function returns a promise, then this method will wait till the promise resolves.</p> |
|
| [$eval(selector, pageFunction, args)](./puppeteer.frame._eval.md) | | <p>Runs the given function on the first element matching the given selector in the frame.</p><p>If the given function returns a promise, then this method will wait till the promise resolves.</p> |
|
||||||
| [$x(expression)](./puppeteer.frame._x.md) | | |
|
|
||||||
| [addScriptTag(options)](./puppeteer.frame.addscripttag.md) | | Adds a <code><script></code> tag into the page with the desired url or content. |
|
| [addScriptTag(options)](./puppeteer.frame.addscripttag.md) | | Adds a <code><script></code> tag into the page with the desired url or content. |
|
||||||
| [addStyleTag(options)](./puppeteer.frame.addstyletag.md) | | Adds a <code>HTMLStyleElement</code> into the frame with the desired URL |
|
| [addStyleTag(options)](./puppeteer.frame.addstyletag.md) | | Adds a <code>HTMLStyleElement</code> into the frame with the desired URL |
|
||||||
| [addStyleTag(options)](./puppeteer.frame.addstyletag_1.md) | | Adds a <code>HTMLLinkElement</code> into the frame with the desired URL |
|
| [addStyleTag(options)](./puppeteer.frame.addstyletag_1.md) | | Adds a <code>HTMLLinkElement</code> into the frame with the desired URL |
|
||||||
@ -103,4 +102,3 @@ console.log(text);
|
|||||||
| [waitForFunction(pageFunction, options, args)](./puppeteer.frame.waitforfunction.md) | | |
|
| [waitForFunction(pageFunction, options, args)](./puppeteer.frame.waitforfunction.md) | | |
|
||||||
| [waitForNavigation(options)](./puppeteer.frame.waitfornavigation.md) | | <p>Waits for the frame to navigate. It is useful for when you run code which will indirectly cause the frame to navigate.</p><p>Usage of the [History API](https://developer.mozilla.org/en-US/docs/Web/API/History_API) to change the URL is considered a navigation.</p> |
|
| [waitForNavigation(options)](./puppeteer.frame.waitfornavigation.md) | | <p>Waits for the frame to navigate. It is useful for when you run code which will indirectly cause the frame to navigate.</p><p>Usage of the [History API](https://developer.mozilla.org/en-US/docs/Web/API/History_API) to change the URL is considered a navigation.</p> |
|
||||||
| [waitForSelector(selector, options)](./puppeteer.frame.waitforselector.md) | | <p>Waits for an element matching the given selector to appear in the frame.</p><p>This method works across navigations.</p> |
|
| [waitForSelector(selector, options)](./puppeteer.frame.waitforselector.md) | | <p>Waits for an element matching the given selector to appear in the frame.</p><p>This method works across navigations.</p> |
|
||||||
| [waitForXPath(xpath, options)](./puppeteer.frame.waitforxpath.md) | | |
|
|
||||||
|
@ -1,39 +0,0 @@
|
|||||||
---
|
|
||||||
sidebar_label: Frame.waitForXPath
|
|
||||||
---
|
|
||||||
|
|
||||||
# Frame.waitForXPath() method
|
|
||||||
|
|
||||||
> Warning: This API is now obsolete.
|
|
||||||
>
|
|
||||||
> Use [Frame.waitForSelector()](./puppeteer.frame.waitforselector.md) with the `xpath` prefix.
|
|
||||||
>
|
|
||||||
> Example: `await frame.waitForSelector('xpath/' + xpathExpression)`
|
|
||||||
>
|
|
||||||
> The method evaluates the XPath expression relative to the Frame. If `xpath` starts with `//` instead of `.//`, the dot will be appended automatically.
|
|
||||||
>
|
|
||||||
> Wait for the `xpath` to appear in page. If at the moment of calling the method the `xpath` already exists, the method will return immediately. If the xpath doesn't appear after the `timeout` milliseconds of waiting, the function will throw.
|
|
||||||
>
|
|
||||||
> For a code example, see the example for [Frame.waitForSelector()](./puppeteer.frame.waitforselector.md). That function behaves identically other than taking a CSS selector rather than an XPath.
|
|
||||||
|
|
||||||
#### Signature:
|
|
||||||
|
|
||||||
```typescript
|
|
||||||
class Frame {
|
|
||||||
waitForXPath(
|
|
||||||
xpath: string,
|
|
||||||
options?: WaitForSelectorOptions
|
|
||||||
): Promise<ElementHandle<Node> | null>;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Parameters
|
|
||||||
|
|
||||||
| Parameter | Type | Description |
|
|
||||||
| --------- | --------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------- |
|
|
||||||
| xpath | string | the XPath expression to wait for. |
|
|
||||||
| options | [WaitForSelectorOptions](./puppeteer.waitforselectoroptions.md) | _(Optional)_ options to configure the visibility of the element and how long to wait before timing out. |
|
|
||||||
|
|
||||||
**Returns:**
|
|
||||||
|
|
||||||
Promise<[ElementHandle](./puppeteer.elementhandle.md)<Node> \| null>
|
|
@ -1,29 +0,0 @@
|
|||||||
---
|
|
||||||
sidebar_label: Page.$x
|
|
||||||
---
|
|
||||||
|
|
||||||
# Page.$x() method
|
|
||||||
|
|
||||||
The method evaluates the XPath expression relative to the page document as its context node. If there are no such elements, the method resolves to an empty array.
|
|
||||||
|
|
||||||
#### Signature:
|
|
||||||
|
|
||||||
```typescript
|
|
||||||
class Page {
|
|
||||||
$x(expression: string): Promise<Array<ElementHandle<Node>>>;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Parameters
|
|
||||||
|
|
||||||
| Parameter | Type | Description |
|
|
||||||
| ---------- | ------ | ---------------------- |
|
|
||||||
| expression | string | Expression to evaluate |
|
|
||||||
|
|
||||||
**Returns:**
|
|
||||||
|
|
||||||
Promise<Array<[ElementHandle](./puppeteer.elementhandle.md)<Node>>>
|
|
||||||
|
|
||||||
## Remarks
|
|
||||||
|
|
||||||
Shortcut for [Page.mainFrame().$x(expression)](./puppeteer.frame._x.md).
|
|
@ -80,7 +80,6 @@ page.off('request', logRequest);
|
|||||||
| [$$(selector)](./puppeteer.page.__.md) | | The method runs <code>document.querySelectorAll</code> within the page. If no elements match the selector, the return value resolves to <code>[]</code>. |
|
| [$$(selector)](./puppeteer.page.__.md) | | The method runs <code>document.querySelectorAll</code> within the page. If no elements match the selector, the return value resolves to <code>[]</code>. |
|
||||||
| [$$eval(selector, pageFunction, args)](./puppeteer.page.__eval.md) | | This method runs <code>Array.from(document.querySelectorAll(selector))</code> within the page and passes the result as the first argument to the <code>pageFunction</code>. |
|
| [$$eval(selector, pageFunction, args)](./puppeteer.page.__eval.md) | | This method runs <code>Array.from(document.querySelectorAll(selector))</code> within the page and passes the result as the first argument to the <code>pageFunction</code>. |
|
||||||
| [$eval(selector, pageFunction, args)](./puppeteer.page._eval.md) | | This method runs <code>document.querySelector</code> within the page and passes the result as the first argument to the <code>pageFunction</code>. |
|
| [$eval(selector, pageFunction, args)](./puppeteer.page._eval.md) | | This method runs <code>document.querySelector</code> within the page and passes the result as the first argument to the <code>pageFunction</code>. |
|
||||||
| [$x(expression)](./puppeteer.page._x.md) | | The method evaluates the XPath expression relative to the page document as its context node. If there are no such elements, the method resolves to an empty array. |
|
|
||||||
| [addScriptTag(options)](./puppeteer.page.addscripttag.md) | | Adds a <code><script></code> tag into the page with the desired URL or content. |
|
| [addScriptTag(options)](./puppeteer.page.addscripttag.md) | | Adds a <code><script></code> tag into the page with the desired URL or content. |
|
||||||
| [addStyleTag(options)](./puppeteer.page.addstyletag.md) | | <p>Adds a <code><link rel="stylesheet"></code> tag into the page with the desired URL or a <code><style type="text/css"></code> tag with the content.</p><p>Shortcut for [page.mainFrame().addStyleTag(options)](./puppeteer.frame.addstyletag_1.md).</p> |
|
| [addStyleTag(options)](./puppeteer.page.addstyletag.md) | | <p>Adds a <code><link rel="stylesheet"></code> tag into the page with the desired URL or a <code><style type="text/css"></code> tag with the content.</p><p>Shortcut for [page.mainFrame().addStyleTag(options)](./puppeteer.frame.addstyletag_1.md).</p> |
|
||||||
| [addStyleTag(options)](./puppeteer.page.addstyletag_1.md) | | |
|
| [addStyleTag(options)](./puppeteer.page.addstyletag_1.md) | | |
|
||||||
@ -161,5 +160,4 @@ page.off('request', logRequest);
|
|||||||
| [waitForRequest(urlOrPredicate, options)](./puppeteer.page.waitforrequest.md) | | |
|
| [waitForRequest(urlOrPredicate, options)](./puppeteer.page.waitforrequest.md) | | |
|
||||||
| [waitForResponse(urlOrPredicate, options)](./puppeteer.page.waitforresponse.md) | | |
|
| [waitForResponse(urlOrPredicate, options)](./puppeteer.page.waitforresponse.md) | | |
|
||||||
| [waitForSelector(selector, options)](./puppeteer.page.waitforselector.md) | | Wait for the <code>selector</code> to appear in page. If at the moment of calling the method the <code>selector</code> already exists, the method will return immediately. If the <code>selector</code> doesn't appear after the <code>timeout</code> milliseconds of waiting, the function will throw. |
|
| [waitForSelector(selector, options)](./puppeteer.page.waitforselector.md) | | Wait for the <code>selector</code> to appear in page. If at the moment of calling the method the <code>selector</code> already exists, the method will return immediately. If the <code>selector</code> doesn't appear after the <code>timeout</code> milliseconds of waiting, the function will throw. |
|
||||||
| [waitForXPath(xpath, options)](./puppeteer.page.waitforxpath.md) | | Wait for the <code>xpath</code> to appear in page. If at the moment of calling the method the <code>xpath</code> already exists, the method will return immediately. If the <code>xpath</code> doesn't appear after the <code>timeout</code> milliseconds of waiting, the function will throw. |
|
|
||||||
| [workers()](./puppeteer.page.workers.md) | | All of the dedicated [WebWorkers](https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API) associated with the page. |
|
| [workers()](./puppeteer.page.workers.md) | | All of the dedicated [WebWorkers](https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API) associated with the page. |
|
||||||
|
@ -1,65 +0,0 @@
|
|||||||
---
|
|
||||||
sidebar_label: Page.waitForXPath
|
|
||||||
---
|
|
||||||
|
|
||||||
# Page.waitForXPath() method
|
|
||||||
|
|
||||||
Wait for the `xpath` to appear in page. If at the moment of calling the method the `xpath` already exists, the method will return immediately. If the `xpath` doesn't appear after the `timeout` milliseconds of waiting, the function will throw.
|
|
||||||
|
|
||||||
#### Signature:
|
|
||||||
|
|
||||||
```typescript
|
|
||||||
class Page {
|
|
||||||
waitForXPath(
|
|
||||||
xpath: string,
|
|
||||||
options?: WaitForSelectorOptions
|
|
||||||
): Promise<ElementHandle<Node> | null>;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Parameters
|
|
||||||
|
|
||||||
| Parameter | Type | Description |
|
|
||||||
| --------- | --------------------------------------------------------------- | --------------------------------------------------------------------------------------- |
|
|
||||||
| xpath | string | A [xpath](https://developer.mozilla.org/en-US/docs/Web/XPath) of an element to wait for |
|
|
||||||
| options | [WaitForSelectorOptions](./puppeteer.waitforselectoroptions.md) | _(Optional)_ Optional waiting parameters |
|
|
||||||
|
|
||||||
**Returns:**
|
|
||||||
|
|
||||||
Promise<[ElementHandle](./puppeteer.elementhandle.md)<Node> \| null>
|
|
||||||
|
|
||||||
Promise which resolves when element specified by xpath string is added to DOM. Resolves to `null` if waiting for `hidden: true` and xpath is not found in DOM, otherwise resolves to `ElementHandle`.
|
|
||||||
|
|
||||||
## Remarks
|
|
||||||
|
|
||||||
The optional Argument `options` have properties:
|
|
||||||
|
|
||||||
- `visible`: A boolean to wait for element to be present in DOM and to be visible, i.e. to not have `display: none` or `visibility: hidden` CSS properties. Defaults to `false`.
|
|
||||||
|
|
||||||
- `hidden`: A boolean wait for element to not be found in the DOM or to be hidden, i.e. have `display: none` or `visibility: hidden` CSS properties. Defaults to `false`.
|
|
||||||
|
|
||||||
- `timeout`: A number which is maximum time to wait for in milliseconds. Defaults to `30000` (30 seconds). Pass `0` to disable timeout. The default value can be changed by using the [Page.setDefaultTimeout()](./puppeteer.page.setdefaulttimeout.md) method.
|
|
||||||
|
|
||||||
## Example
|
|
||||||
|
|
||||||
This method works across navigation
|
|
||||||
|
|
||||||
```ts
|
|
||||||
import puppeteer from 'puppeteer';
|
|
||||||
(async () => {
|
|
||||||
const browser = await puppeteer.launch();
|
|
||||||
const page = await browser.newPage();
|
|
||||||
let currentURL;
|
|
||||||
page
|
|
||||||
.waitForXPath('//img')
|
|
||||||
.then(() => console.log('First URL with image: ' + currentURL));
|
|
||||||
for (currentURL of [
|
|
||||||
'https://example.com',
|
|
||||||
'https://google.com',
|
|
||||||
'https://bbc.com',
|
|
||||||
]) {
|
|
||||||
await page.goto(currentURL);
|
|
||||||
}
|
|
||||||
await browser.close();
|
|
||||||
})();
|
|
||||||
```
|
|
@ -476,27 +476,6 @@ export abstract class ElementHandle<
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated Use {@link ElementHandle.$$} with the `xpath` prefix.
|
|
||||||
*
|
|
||||||
* Example: `await elementHandle.$$('xpath/' + xpathExpression)`
|
|
||||||
*
|
|
||||||
* The method evaluates the XPath expression relative to the elementHandle.
|
|
||||||
* If `xpath` starts with `//` instead of `.//`, the dot will be appended
|
|
||||||
* automatically.
|
|
||||||
*
|
|
||||||
* If there are no such elements, the method will resolve to an empty array.
|
|
||||||
* @param expression - Expression to {@link https://developer.mozilla.org/en-US/docs/Web/API/Document/evaluate | evaluate}
|
|
||||||
*/
|
|
||||||
@throwIfDisposed()
|
|
||||||
@ElementHandle.bindIsolatedHandle
|
|
||||||
async $x(expression: string): Promise<Array<ElementHandle<Node>>> {
|
|
||||||
if (expression.startsWith('//')) {
|
|
||||||
expression = `.${expression}`;
|
|
||||||
}
|
|
||||||
return await this.$$(`xpath/${expression}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Wait for an element matching the given selector to appear in the current
|
* Wait for an element matching the given selector to appear in the current
|
||||||
* element.
|
* element.
|
||||||
@ -581,84 +560,6 @@ export abstract class ElementHandle<
|
|||||||
return await this.#checkVisibility(false);
|
return await this.#checkVisibility(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated Use {@link ElementHandle.waitForSelector} with the `xpath`
|
|
||||||
* prefix.
|
|
||||||
*
|
|
||||||
* Example: `await elementHandle.waitForSelector('xpath/' + xpathExpression)`
|
|
||||||
*
|
|
||||||
* The method evaluates the XPath expression relative to the elementHandle.
|
|
||||||
*
|
|
||||||
* Wait for the `xpath` within the element. If at the moment of calling the
|
|
||||||
* method the `xpath` already exists, the method will return immediately. If
|
|
||||||
* the `xpath` doesn't appear after the `timeout` milliseconds of waiting, the
|
|
||||||
* function will throw.
|
|
||||||
*
|
|
||||||
* If `xpath` starts with `//` instead of `.//`, the dot will be appended
|
|
||||||
* automatically.
|
|
||||||
*
|
|
||||||
* @example
|
|
||||||
* This method works across navigation.
|
|
||||||
*
|
|
||||||
* ```ts
|
|
||||||
* import puppeteer from 'puppeteer';
|
|
||||||
* (async () => {
|
|
||||||
* const browser = await puppeteer.launch();
|
|
||||||
* const page = await browser.newPage();
|
|
||||||
* let currentURL;
|
|
||||||
* page
|
|
||||||
* .waitForXPath('//img')
|
|
||||||
* .then(() => console.log('First URL with image: ' + currentURL));
|
|
||||||
* for (currentURL of [
|
|
||||||
* 'https://example.com',
|
|
||||||
* 'https://google.com',
|
|
||||||
* 'https://bbc.com',
|
|
||||||
* ]) {
|
|
||||||
* await page.goto(currentURL);
|
|
||||||
* }
|
|
||||||
* await browser.close();
|
|
||||||
* })();
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* @param xpath - A
|
|
||||||
* {@link https://developer.mozilla.org/en-US/docs/Web/XPath | xpath} of an
|
|
||||||
* element to wait for
|
|
||||||
* @param options - Optional waiting parameters
|
|
||||||
* @returns Promise which resolves when element specified by xpath string is
|
|
||||||
* added to DOM. Resolves to `null` if waiting for `hidden: true` and xpath is
|
|
||||||
* not found in DOM, otherwise resolves to `ElementHandle`.
|
|
||||||
* @remarks
|
|
||||||
* The optional Argument `options` have properties:
|
|
||||||
*
|
|
||||||
* - `visible`: A boolean to wait for element to be present in DOM and to be
|
|
||||||
* visible, i.e. to not have `display: none` or `visibility: hidden` CSS
|
|
||||||
* properties. Defaults to `false`.
|
|
||||||
*
|
|
||||||
* - `hidden`: A boolean wait for element to not be found in the DOM or to be
|
|
||||||
* hidden, i.e. have `display: none` or `visibility: hidden` CSS properties.
|
|
||||||
* Defaults to `false`.
|
|
||||||
*
|
|
||||||
* - `timeout`: A number which is maximum time to wait for in milliseconds.
|
|
||||||
* Defaults to `30000` (30 seconds). Pass `0` to disable timeout. The
|
|
||||||
* default value can be changed by using the {@link Page.setDefaultTimeout}
|
|
||||||
* method.
|
|
||||||
*/
|
|
||||||
@throwIfDisposed()
|
|
||||||
@ElementHandle.bindIsolatedHandle
|
|
||||||
async waitForXPath(
|
|
||||||
xpath: string,
|
|
||||||
options: {
|
|
||||||
visible?: boolean;
|
|
||||||
hidden?: boolean;
|
|
||||||
timeout?: number;
|
|
||||||
} = {}
|
|
||||||
): Promise<ElementHandle<Node> | null> {
|
|
||||||
if (xpath.startsWith('//')) {
|
|
||||||
xpath = `.${xpath}`;
|
|
||||||
}
|
|
||||||
return await this.waitForSelector(`xpath/${xpath}`, options);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts the current handle to the given element type.
|
* Converts the current handle to the given element type.
|
||||||
*
|
*
|
||||||
|
@ -623,23 +623,6 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
|
|||||||
return await document.$$eval(selector, pageFunction, ...args);
|
return await document.$$eval(selector, pageFunction, ...args);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated Use {@link Frame.$$} with the `xpath` prefix.
|
|
||||||
*
|
|
||||||
* Example: `await frame.$$('xpath/' + xpathExpression)`
|
|
||||||
*
|
|
||||||
* This method evaluates the given XPath expression and returns the results.
|
|
||||||
* If `xpath` starts with `//` instead of `.//`, the dot will be appended
|
|
||||||
* automatically.
|
|
||||||
* @param expression - the XPath expression to evaluate.
|
|
||||||
*/
|
|
||||||
@throwIfDetached
|
|
||||||
async $x(expression: string): Promise<Array<ElementHandle<Node>>> {
|
|
||||||
// eslint-disable-next-line rulesdir/use-using -- This is cached.
|
|
||||||
const document = await this.#document();
|
|
||||||
return await document.$x(expression);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Waits for an element matching the given selector to appear in the frame.
|
* Waits for an element matching the given selector to appear in the frame.
|
||||||
*
|
*
|
||||||
@ -689,39 +672,6 @@ export abstract class Frame extends EventEmitter<FrameEvents> {
|
|||||||
)) as ElementHandle<NodeFor<Selector>> | null;
|
)) as ElementHandle<NodeFor<Selector>> | null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated Use {@link Frame.waitForSelector} with the `xpath` prefix.
|
|
||||||
*
|
|
||||||
* Example: `await frame.waitForSelector('xpath/' + xpathExpression)`
|
|
||||||
*
|
|
||||||
* The method evaluates the XPath expression relative to the Frame.
|
|
||||||
* If `xpath` starts with `//` instead of `.//`, the dot will be appended
|
|
||||||
* automatically.
|
|
||||||
*
|
|
||||||
* Wait for the `xpath` to appear in page. If at the moment of calling the
|
|
||||||
* method the `xpath` already exists, the method will return immediately. If
|
|
||||||
* the xpath doesn't appear after the `timeout` milliseconds of waiting, the
|
|
||||||
* function will throw.
|
|
||||||
*
|
|
||||||
* For a code example, see the example for {@link Frame.waitForSelector}. That
|
|
||||||
* function behaves identically other than taking a CSS selector rather than
|
|
||||||
* an XPath.
|
|
||||||
*
|
|
||||||
* @param xpath - the XPath expression to wait for.
|
|
||||||
* @param options - options to configure the visibility of the element and how
|
|
||||||
* long to wait before timing out.
|
|
||||||
*/
|
|
||||||
@throwIfDetached
|
|
||||||
async waitForXPath(
|
|
||||||
xpath: string,
|
|
||||||
options: WaitForSelectorOptions = {}
|
|
||||||
): Promise<ElementHandle<Node> | null> {
|
|
||||||
if (xpath.startsWith('//')) {
|
|
||||||
xpath = `.${xpath}`;
|
|
||||||
}
|
|
||||||
return await this.waitForSelector(`xpath/${xpath}`, options);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @example
|
* @example
|
||||||
* The `waitForFunction` can be used to observe viewport size change:
|
* The `waitForFunction` can be used to observe viewport size change:
|
||||||
|
@ -1290,20 +1290,6 @@ export abstract class Page extends EventEmitter<PageEvents> {
|
|||||||
return await this.mainFrame().$$eval(selector, pageFunction, ...args);
|
return await this.mainFrame().$$eval(selector, pageFunction, ...args);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The method evaluates the XPath expression relative to the page document as
|
|
||||||
* its context node. If there are no such elements, the method resolves to an
|
|
||||||
* empty array.
|
|
||||||
*
|
|
||||||
* @remarks
|
|
||||||
* Shortcut for {@link Frame.$x | Page.mainFrame().$x(expression) }.
|
|
||||||
*
|
|
||||||
* @param expression - Expression to evaluate
|
|
||||||
*/
|
|
||||||
async $x(expression: string): Promise<Array<ElementHandle<Node>>> {
|
|
||||||
return await this.mainFrame().$x(expression);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If no URLs are specified, this method returns cookies for the current page
|
* If no URLs are specified, this method returns cookies for the current page
|
||||||
* URL. If URLs are specified, only cookies for those URLs are returned.
|
* URL. If URLs are specified, only cookies for those URLs are returned.
|
||||||
@ -2843,64 +2829,6 @@ export abstract class Page extends EventEmitter<PageEvents> {
|
|||||||
return await this.mainFrame().waitForSelector(selector, options);
|
return await this.mainFrame().waitForSelector(selector, options);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Wait for the `xpath` to appear in page. If at the moment of calling the
|
|
||||||
* method the `xpath` already exists, the method will return immediately. If
|
|
||||||
* the `xpath` doesn't appear after the `timeout` milliseconds of waiting, the
|
|
||||||
* function will throw.
|
|
||||||
*
|
|
||||||
* @example
|
|
||||||
* This method works across navigation
|
|
||||||
*
|
|
||||||
* ```ts
|
|
||||||
* import puppeteer from 'puppeteer';
|
|
||||||
* (async () => {
|
|
||||||
* const browser = await puppeteer.launch();
|
|
||||||
* const page = await browser.newPage();
|
|
||||||
* let currentURL;
|
|
||||||
* page
|
|
||||||
* .waitForXPath('//img')
|
|
||||||
* .then(() => console.log('First URL with image: ' + currentURL));
|
|
||||||
* for (currentURL of [
|
|
||||||
* 'https://example.com',
|
|
||||||
* 'https://google.com',
|
|
||||||
* 'https://bbc.com',
|
|
||||||
* ]) {
|
|
||||||
* await page.goto(currentURL);
|
|
||||||
* }
|
|
||||||
* await browser.close();
|
|
||||||
* })();
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* @param xpath - A
|
|
||||||
* {@link https://developer.mozilla.org/en-US/docs/Web/XPath | xpath} of an
|
|
||||||
* element to wait for
|
|
||||||
* @param options - Optional waiting parameters
|
|
||||||
* @returns Promise which resolves when element specified by xpath string is
|
|
||||||
* added to DOM. Resolves to `null` if waiting for `hidden: true` and xpath is
|
|
||||||
* not found in DOM, otherwise resolves to `ElementHandle`.
|
|
||||||
* @remarks
|
|
||||||
* The optional Argument `options` have properties:
|
|
||||||
*
|
|
||||||
* - `visible`: A boolean to wait for element to be present in DOM and to be
|
|
||||||
* visible, i.e. to not have `display: none` or `visibility: hidden` CSS
|
|
||||||
* properties. Defaults to `false`.
|
|
||||||
*
|
|
||||||
* - `hidden`: A boolean wait for element to not be found in the DOM or to be
|
|
||||||
* hidden, i.e. have `display: none` or `visibility: hidden` CSS properties.
|
|
||||||
* Defaults to `false`.
|
|
||||||
*
|
|
||||||
* - `timeout`: A number which is maximum time to wait for in milliseconds.
|
|
||||||
* Defaults to `30000` (30 seconds). Pass `0` to disable timeout. The default
|
|
||||||
* value can be changed by using the {@link Page.setDefaultTimeout} method.
|
|
||||||
*/
|
|
||||||
waitForXPath(
|
|
||||||
xpath: string,
|
|
||||||
options?: WaitForSelectorOptions
|
|
||||||
): Promise<ElementHandle<Node> | null> {
|
|
||||||
return this.mainFrame().waitForXPath(xpath, options);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Waits for the provided function, `pageFunction`, to return a truthy value when
|
* Waits for the provided function, `pageFunction`, to return a truthy value when
|
||||||
* evaluated in the page's context.
|
* evaluated in the page's context.
|
||||||
|
@ -3704,25 +3704,25 @@
|
|||||||
"expectations": ["SKIP"]
|
"expectations": ["SKIP"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"testIdPattern": "[waittask.spec] waittask specs Frame.waitForXPath should run in specified frame",
|
"testIdPattern": "[waittask.spec] waittask specs Frame.waitForSelector xpath should run in specified frame",
|
||||||
"platforms": ["darwin", "linux", "win32"],
|
"platforms": ["darwin", "linux", "win32"],
|
||||||
"parameters": ["firefox", "webDriverBiDi"],
|
"parameters": ["firefox", "webDriverBiDi"],
|
||||||
"expectations": ["PASS"]
|
"expectations": ["PASS"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"testIdPattern": "[waittask.spec] waittask specs Frame.waitForXPath should run in specified frame",
|
"testIdPattern": "[waittask.spec] waittask specs Frame.waitForSelector xpath should run in specified frame",
|
||||||
"platforms": ["darwin", "linux", "win32"],
|
"platforms": ["darwin", "linux", "win32"],
|
||||||
"parameters": ["cdp", "firefox"],
|
"parameters": ["cdp", "firefox"],
|
||||||
"expectations": ["SKIP"]
|
"expectations": ["SKIP"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"testIdPattern": "[waittask.spec] waittask specs Frame.waitForXPath should throw when frame is detached",
|
"testIdPattern": "[waittask.spec] waittask specs Frame.waitForSelector xpath should throw when frame is detached",
|
||||||
"platforms": ["darwin", "linux", "win32"],
|
"platforms": ["darwin", "linux", "win32"],
|
||||||
"parameters": ["firefox", "webDriverBiDi"],
|
"parameters": ["firefox", "webDriverBiDi"],
|
||||||
"expectations": ["PASS"]
|
"expectations": ["PASS"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"testIdPattern": "[waittask.spec] waittask specs Frame.waitForXPath should throw when frame is detached",
|
"testIdPattern": "[waittask.spec] waittask specs Frame.waitForSelector xpath should throw when frame is detached",
|
||||||
"platforms": ["darwin", "linux", "win32"],
|
"platforms": ["darwin", "linux", "win32"],
|
||||||
"parameters": ["cdp", "firefox"],
|
"parameters": ["cdp", "firefox"],
|
||||||
"expectations": ["SKIP"]
|
"expectations": ["SKIP"]
|
||||||
|
@ -472,10 +472,8 @@ describe('ElementHandle specs', function () {
|
|||||||
})
|
})
|
||||||
).toStrictEqual('bar1');
|
).toStrictEqual('bar1');
|
||||||
});
|
});
|
||||||
});
|
|
||||||
|
|
||||||
describe('Element.waitForXPath', () => {
|
it('should wait correctly with waitForSelector and xpath on an element', async () => {
|
||||||
it('should wait correctly with waitForXPath on an element', async () => {
|
|
||||||
const {page} = await getTestState();
|
const {page} = await getTestState();
|
||||||
// Set the page content after the waitFor has been started.
|
// Set the page content after the waitFor has been started.
|
||||||
await page.setContent(
|
await page.setContent(
|
||||||
@ -490,20 +488,18 @@ describe('ElementHandle specs', function () {
|
|||||||
</div>`
|
</div>`
|
||||||
);
|
);
|
||||||
|
|
||||||
using el1 = (await page.waitForSelector(
|
using elById = (await page.waitForSelector(
|
||||||
'#el1'
|
'#el1'
|
||||||
)) as ElementHandle<HTMLDivElement>;
|
)) as ElementHandle<HTMLDivElement>;
|
||||||
|
|
||||||
for (const path of ['//div', './/div']) {
|
using elByXpath = (await elById.waitForSelector(
|
||||||
using e = (await el1.waitForXPath(
|
'xpath/.//div'
|
||||||
path
|
)) as ElementHandle<HTMLDivElement>;
|
||||||
)) as ElementHandle<HTMLDivElement>;
|
expect(
|
||||||
expect(
|
await elByXpath.evaluate(el => {
|
||||||
await e.evaluate(el => {
|
return el.id;
|
||||||
return el.id;
|
})
|
||||||
})
|
).toStrictEqual('el2');
|
||||||
).toStrictEqual('el2');
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -174,29 +174,29 @@ describe('querySelector', function () {
|
|||||||
const elements = await page.$$('div');
|
const elements = await page.$$('div');
|
||||||
expect(elements).toHaveLength(0);
|
expect(elements).toHaveLength(0);
|
||||||
});
|
});
|
||||||
});
|
|
||||||
|
|
||||||
describe('Page.$x', function () {
|
describe('xpath', function () {
|
||||||
it('should query existing element', async () => {
|
it('should query existing element', async () => {
|
||||||
const {page} = await getTestState();
|
const {page} = await getTestState();
|
||||||
|
|
||||||
await page.setContent('<section>test</section>');
|
await page.setContent('<section>test</section>');
|
||||||
const elements = await page.$x('/html/body/section');
|
const elements = await page.$$('xpath/html/body/section');
|
||||||
expect(elements[0]).toBeTruthy();
|
expect(elements[0]).toBeTruthy();
|
||||||
expect(elements).toHaveLength(1);
|
expect(elements).toHaveLength(1);
|
||||||
});
|
});
|
||||||
it('should return empty array for non-existing element', async () => {
|
it('should return empty array for non-existing element', async () => {
|
||||||
const {page} = await getTestState();
|
const {page} = await getTestState();
|
||||||
|
|
||||||
const element = await page.$x('/html/body/non-existing-element');
|
const element = await page.$$('xpath/html/body/non-existing-element');
|
||||||
expect(element).toEqual([]);
|
expect(element).toEqual([]);
|
||||||
});
|
});
|
||||||
it('should return multiple elements', async () => {
|
it('should return multiple elements', async () => {
|
||||||
const {page} = await getTestState();
|
const {page} = await getTestState();
|
||||||
|
|
||||||
await page.setContent('<div></div><div></div>');
|
await page.setContent('<div></div><div></div>');
|
||||||
const elements = await page.$x('/html/body/div');
|
const elements = await page.$$('xpath/html/body/div');
|
||||||
expect(elements).toHaveLength(2);
|
expect(elements).toHaveLength(2);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -347,37 +347,40 @@ describe('querySelector', function () {
|
|||||||
const elements = await html.$$('div');
|
const elements = await html.$$('div');
|
||||||
expect(elements).toHaveLength(0);
|
expect(elements).toHaveLength(0);
|
||||||
});
|
});
|
||||||
});
|
|
||||||
|
|
||||||
describe('ElementHandle.$x', function () {
|
describe('xpath', function () {
|
||||||
it('should query existing element', async () => {
|
it('should query existing element', async () => {
|
||||||
const {page, server} = await getTestState();
|
const {page, server} = await getTestState();
|
||||||
|
|
||||||
await page.goto(server.PREFIX + '/playground.html');
|
await page.goto(server.PREFIX + '/playground.html');
|
||||||
await page.setContent(
|
await page.setContent(
|
||||||
'<html><body><div class="second"><div class="inner">A</div></div></body></html>'
|
'<html><body><div class="second"><div class="inner">A</div></div></body></html>'
|
||||||
);
|
);
|
||||||
using html = (await page.$('html'))!;
|
using html = (await page.$('html'))!;
|
||||||
const second = await html.$x(`./body/div[contains(@class, 'second')]`);
|
const second = await html.$$(
|
||||||
const inner = await second[0]!.$x(`./div[contains(@class, 'inner')]`);
|
`xpath/./body/div[contains(@class, 'second')]`
|
||||||
const content = await page.evaluate(e => {
|
);
|
||||||
return e.textContent;
|
const inner = await second[0]!.$$(
|
||||||
}, inner[0]!);
|
`xpath/./div[contains(@class, 'inner')]`
|
||||||
expect(content).toBe('A');
|
);
|
||||||
});
|
const content = await page.evaluate(e => {
|
||||||
|
return e.textContent;
|
||||||
|
}, inner[0]!);
|
||||||
|
expect(content).toBe('A');
|
||||||
|
});
|
||||||
|
|
||||||
it('should return null for non-existing element', async () => {
|
it('should return null for non-existing element', async () => {
|
||||||
const {page} = await getTestState();
|
const {page} = await getTestState();
|
||||||
|
|
||||||
await page.setContent(
|
await page.setContent(
|
||||||
'<html><body><div class="second"><div class="inner">B</div></div></body></html>'
|
'<html><body><div class="second"><div class="inner">B</div></div></body></html>'
|
||||||
);
|
);
|
||||||
using html = (await page.$('html'))!;
|
using html = (await page.$('html'))!;
|
||||||
const second = await html.$x(`/div[contains(@class, 'third')]`);
|
const second = await html.$$(`xpath/div[contains(@class, 'third')]`);
|
||||||
expect(second).toEqual([]);
|
expect(second).toEqual([]);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
// This is the same tests for `$$eval` and `$$` as above, but with a queryAll
|
// This is the same tests for `$$eval` and `$$` as above, but with a queryAll
|
||||||
// handler that returns an array instead of a list of nodes.
|
// handler that returns an array instead of a list of nodes.
|
||||||
describe('QueryAll', function () {
|
describe('QueryAll', function () {
|
||||||
|
@ -693,142 +693,150 @@ describe('waittask specs', function () {
|
|||||||
// The extension is ts here as Mocha maps back via sourcemaps.
|
// The extension is ts here as Mocha maps back via sourcemaps.
|
||||||
expect(error?.stack).toContain('WaitTask.ts');
|
expect(error?.stack).toContain('WaitTask.ts');
|
||||||
});
|
});
|
||||||
});
|
|
||||||
|
|
||||||
describe('Frame.waitForXPath', function () {
|
describe('xpath', function () {
|
||||||
const addElement = (tag: string) => {
|
const addElement = (tag: string) => {
|
||||||
return document.body.appendChild(document.createElement(tag));
|
return document.body.appendChild(document.createElement(tag));
|
||||||
};
|
};
|
||||||
|
|
||||||
it('should support some fancy xpath', async () => {
|
it('should support some fancy xpath', async () => {
|
||||||
const {page} = await getTestState();
|
const {page} = await getTestState();
|
||||||
|
|
||||||
await page.setContent(`<p>red herring</p><p>hello world </p>`);
|
await page.setContent(`<p>red herring</p><p>hello world </p>`);
|
||||||
const waitForXPath = page.waitForXPath(
|
const waitForSelector = page.waitForSelector(
|
||||||
'//p[normalize-space(.)="hello world"]'
|
'xpath/.//p[normalize-space(.)="hello world"]'
|
||||||
);
|
);
|
||||||
expect(
|
expect(
|
||||||
await page.evaluate(
|
await page.evaluate(
|
||||||
x => {
|
x => {
|
||||||
return x?.textContent;
|
return x?.textContent;
|
||||||
},
|
},
|
||||||
await waitForXPath
|
await waitForSelector
|
||||||
)
|
)
|
||||||
).toBe('hello world ');
|
).toBe('hello world ');
|
||||||
});
|
|
||||||
it('should respect timeout', async () => {
|
|
||||||
const {page} = await getTestState();
|
|
||||||
|
|
||||||
let error!: Error;
|
|
||||||
await page.waitForXPath('//div', {timeout: 10}).catch(error_ => {
|
|
||||||
return (error = error_);
|
|
||||||
});
|
});
|
||||||
expect(error).toBeInstanceOf(TimeoutError);
|
it('should respect timeout', async () => {
|
||||||
expect(error?.message).toContain('Waiting failed: 10ms exceeded');
|
const {page} = await getTestState();
|
||||||
});
|
|
||||||
it('should run in specified frame', async () => {
|
|
||||||
const {page, server} = await getTestState();
|
|
||||||
|
|
||||||
await attachFrame(page, 'frame1', server.EMPTY_PAGE);
|
let error!: Error;
|
||||||
await attachFrame(page, 'frame2', server.EMPTY_PAGE);
|
await page
|
||||||
const frame1 = page.frames()[1]!;
|
.waitForSelector('xpath/.//div', {timeout: 10})
|
||||||
const frame2 = page.frames()[2]!;
|
.catch(error_ => {
|
||||||
const waitForXPathPromise = frame2.waitForXPath('//div');
|
return (error = error_);
|
||||||
await frame1.evaluate(addElement, 'div');
|
});
|
||||||
await frame2.evaluate(addElement, 'div');
|
expect(error).toBeInstanceOf(TimeoutError);
|
||||||
using eHandle = await waitForXPathPromise;
|
expect(error?.message).toContain('Waiting failed: 10ms exceeded');
|
||||||
expect(eHandle?.frame).toBe(frame2);
|
|
||||||
});
|
|
||||||
it('should throw when frame is detached', async () => {
|
|
||||||
const {page, server} = await getTestState();
|
|
||||||
|
|
||||||
await attachFrame(page, 'frame1', server.EMPTY_PAGE);
|
|
||||||
const frame = page.frames()[1]!;
|
|
||||||
let waitError: Error | undefined;
|
|
||||||
const waitPromise = frame
|
|
||||||
.waitForXPath('//*[@class="box"]')
|
|
||||||
.catch(error => {
|
|
||||||
return (waitError = error);
|
|
||||||
});
|
|
||||||
await detachFrame(page, 'frame1');
|
|
||||||
await waitPromise;
|
|
||||||
expect(waitError).toBeTruthy();
|
|
||||||
expect(waitError?.message).toContain(
|
|
||||||
'waitForFunction failed: frame got detached.'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
it('hidden should wait for display: none', async () => {
|
|
||||||
const {page} = await getTestState();
|
|
||||||
|
|
||||||
let divHidden = false;
|
|
||||||
await page.setContent(`<div style='display: block;'>text</div>`);
|
|
||||||
const waitForXPath = page
|
|
||||||
.waitForXPath('//div', {hidden: true})
|
|
||||||
.then(() => {
|
|
||||||
return (divHidden = true);
|
|
||||||
});
|
|
||||||
await page.waitForXPath('//div'); // do a round trip
|
|
||||||
expect(divHidden).toBe(false);
|
|
||||||
await page.evaluate(() => {
|
|
||||||
return document
|
|
||||||
.querySelector('div')
|
|
||||||
?.style.setProperty('display', 'none');
|
|
||||||
});
|
});
|
||||||
expect(await waitForXPath).toBe(true);
|
it('should run in specified frame', async () => {
|
||||||
expect(divHidden).toBe(true);
|
const {page, server} = await getTestState();
|
||||||
});
|
|
||||||
it('hidden should return null if the element is not found', async () => {
|
|
||||||
const {page} = await getTestState();
|
|
||||||
|
|
||||||
using waitForXPath = await page.waitForXPath('//div', {hidden: true});
|
await attachFrame(page, 'frame1', server.EMPTY_PAGE);
|
||||||
|
await attachFrame(page, 'frame2', server.EMPTY_PAGE);
|
||||||
|
const frame1 = page.frames()[1]!;
|
||||||
|
const frame2 = page.frames()[2]!;
|
||||||
|
const waitForSelector = frame2.waitForSelector('xpath/.//div');
|
||||||
|
await frame1.evaluate(addElement, 'div');
|
||||||
|
await frame2.evaluate(addElement, 'div');
|
||||||
|
using eHandle = await waitForSelector;
|
||||||
|
expect(eHandle?.frame).toBe(frame2);
|
||||||
|
});
|
||||||
|
it('should throw when frame is detached', async () => {
|
||||||
|
const {page, server} = await getTestState();
|
||||||
|
|
||||||
expect(waitForXPath).toBe(null);
|
await attachFrame(page, 'frame1', server.EMPTY_PAGE);
|
||||||
});
|
const frame = page.frames()[1]!;
|
||||||
it('hidden should return an empty element handle if the element is found', async () => {
|
let waitError: Error | undefined;
|
||||||
const {page} = await getTestState();
|
const waitPromise = frame
|
||||||
|
.waitForSelector('xpath/.//*[@class="box"]')
|
||||||
|
.catch(error => {
|
||||||
|
return (waitError = error);
|
||||||
|
});
|
||||||
|
await detachFrame(page, 'frame1');
|
||||||
|
await waitPromise;
|
||||||
|
expect(waitError).toBeTruthy();
|
||||||
|
expect(waitError?.message).toContain(
|
||||||
|
'waitForFunction failed: frame got detached.'
|
||||||
|
);
|
||||||
|
});
|
||||||
|
it('hidden should wait for display: none', async () => {
|
||||||
|
const {page} = await getTestState();
|
||||||
|
|
||||||
await page.setContent(`<div style='display: none;'>text</div>`);
|
let divHidden = false;
|
||||||
|
await page.setContent(`<div style='display: block;'>text</div>`);
|
||||||
|
const waitForSelector = page
|
||||||
|
.waitForSelector('xpath/.//div', {hidden: true})
|
||||||
|
.then(() => {
|
||||||
|
return (divHidden = true);
|
||||||
|
});
|
||||||
|
await page.waitForSelector('xpath/.//div'); // do a round trip
|
||||||
|
expect(divHidden).toBe(false);
|
||||||
|
await page.evaluate(() => {
|
||||||
|
return document
|
||||||
|
.querySelector('div')
|
||||||
|
?.style.setProperty('display', 'none');
|
||||||
|
});
|
||||||
|
expect(await waitForSelector).toBe(true);
|
||||||
|
expect(divHidden).toBe(true);
|
||||||
|
});
|
||||||
|
it('hidden should return null if the element is not found', async () => {
|
||||||
|
const {page} = await getTestState();
|
||||||
|
|
||||||
using waitForXPath = await page.waitForXPath('//div', {hidden: true});
|
using waitForSelector = await page.waitForSelector('xpath/.//div', {
|
||||||
|
hidden: true,
|
||||||
|
});
|
||||||
|
|
||||||
expect(waitForXPath).toBeInstanceOf(ElementHandle);
|
expect(waitForSelector).toBe(null);
|
||||||
});
|
});
|
||||||
it('should return the element handle', async () => {
|
it('hidden should return an empty element handle if the element is found', async () => {
|
||||||
const {page} = await getTestState();
|
const {page} = await getTestState();
|
||||||
|
|
||||||
const waitForXPath = page.waitForXPath('//*[@class="zombo"]');
|
await page.setContent(`<div style='display: none;'>text</div>`);
|
||||||
await page.setContent(`<div class='zombo'>anything</div>`);
|
|
||||||
expect(
|
|
||||||
await page.evaluate(
|
|
||||||
x => {
|
|
||||||
return x?.textContent;
|
|
||||||
},
|
|
||||||
await waitForXPath
|
|
||||||
)
|
|
||||||
).toBe('anything');
|
|
||||||
});
|
|
||||||
it('should allow you to select a text node', async () => {
|
|
||||||
const {page} = await getTestState();
|
|
||||||
|
|
||||||
await page.setContent(`<div>some text</div>`);
|
using waitForSelector = await page.waitForSelector('xpath/.//div', {
|
||||||
using text = await page.waitForXPath('//div/text()');
|
hidden: true,
|
||||||
expect(await (await text!.getProperty('nodeType')!).jsonValue()).toBe(
|
});
|
||||||
3 /* Node.TEXT_NODE */
|
|
||||||
);
|
|
||||||
});
|
|
||||||
it('should allow you to select an element with single slash', async () => {
|
|
||||||
const {page} = await getTestState();
|
|
||||||
|
|
||||||
await page.setContent(`<div>some text</div>`);
|
expect(waitForSelector).toBeInstanceOf(ElementHandle);
|
||||||
const waitForXPath = page.waitForXPath('/html/body/div');
|
});
|
||||||
expect(
|
it('should return the element handle', async () => {
|
||||||
await page.evaluate(
|
const {page} = await getTestState();
|
||||||
x => {
|
|
||||||
return x?.textContent;
|
const waitForSelector = page.waitForSelector(
|
||||||
},
|
'xpath/.//*[@class="zombo"]'
|
||||||
await waitForXPath
|
);
|
||||||
)
|
await page.setContent(`<div class='zombo'>anything</div>`);
|
||||||
).toBe('some text');
|
expect(
|
||||||
|
await page.evaluate(
|
||||||
|
x => {
|
||||||
|
return x?.textContent;
|
||||||
|
},
|
||||||
|
await waitForSelector
|
||||||
|
)
|
||||||
|
).toBe('anything');
|
||||||
|
});
|
||||||
|
it('should allow you to select a text node', async () => {
|
||||||
|
const {page} = await getTestState();
|
||||||
|
|
||||||
|
await page.setContent(`<div>some text</div>`);
|
||||||
|
using text = await page.waitForSelector('xpath/.//div/text()');
|
||||||
|
expect(await (await text!.getProperty('nodeType')!).jsonValue()).toBe(
|
||||||
|
3 /* Node.TEXT_NODE */
|
||||||
|
);
|
||||||
|
});
|
||||||
|
it('should allow you to select an element with single slash', async () => {
|
||||||
|
const {page} = await getTestState();
|
||||||
|
|
||||||
|
await page.setContent(`<div>some text</div>`);
|
||||||
|
const waitForSelector = page.waitForSelector('xpath/html/body/div');
|
||||||
|
expect(
|
||||||
|
await page.evaluate(
|
||||||
|
x => {
|
||||||
|
return x?.textContent;
|
||||||
|
},
|
||||||
|
await waitForSelector
|
||||||
|
)
|
||||||
|
).toBe('some text');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -30,7 +30,7 @@ Promise<void>
|
|||||||
|
|
||||||
## Remarks
|
## Remarks
|
||||||
|
|
||||||
It's generally recommended to not wait for a number of seconds, but instead use [Frame.waitForSelector()](./puppeteer.frame.waitforselector.md), [Frame.waitForXPath()](./puppeteer.frame.waitforxpath.md) or [Frame.waitForFunction()](./puppeteer.frame.waitforfunction.md) to wait for exactly the conditions you want.
|
It's generally recommended to not wait for a number of seconds, but instead use [Frame.waitForSelector()](./puppeteer.frame.waitforselector.md), or [Frame.waitForFunction()](./puppeteer.frame.waitforfunction.md) to wait for exactly the conditions you want.
|
||||||
|
|
||||||
## Example
|
## Example
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ Promise<void>
|
|||||||
|
|
||||||
## Remarks
|
## Remarks
|
||||||
|
|
||||||
It's generally recommended to not wait for a number of seconds, but instead use [Frame.waitForSelector()](./puppeteer.frame.waitforselector.md), [Frame.waitForXPath()](./puppeteer.frame.waitforxpath.md) or [Frame.waitForFunction()](./puppeteer.frame.waitforfunction.md) to wait for exactly the conditions you want.
|
It's generally recommended to not wait for a number of seconds, but instead use [Frame.waitForSelector()](./puppeteer.frame.waitforselector.md), or [Frame.waitForFunction()](./puppeteer.frame.waitforfunction.md) to wait for exactly the conditions you want.
|
||||||
|
|
||||||
## Example
|
## Example
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user