2022-08-06 14:49:20 +00:00
|
|
|
---
|
|
|
|
sidebar_label: Browser.waitForTarget
|
|
|
|
---
|
|
|
|
|
|
|
|
# Browser.waitForTarget() method
|
|
|
|
|
2023-09-19 13:03:19 +00:00
|
|
|
Waits until a [target](./puppeteer.target.md) matching the given `predicate` appears and returns it.
|
|
|
|
|
|
|
|
This will look all open [browser contexts](./puppeteer.browsercontext.md).
|
2022-08-06 14:49:20 +00:00
|
|
|
|
2022-10-24 14:31:12 +00:00
|
|
|
#### Signature:
|
2022-08-06 14:49:20 +00:00
|
|
|
|
|
|
|
```typescript
|
|
|
|
class Browser {
|
|
|
|
waitForTarget(
|
|
|
|
predicate: (x: Target) => boolean | Promise<boolean>,
|
|
|
|
options?: WaitForTargetOptions
|
|
|
|
): Promise<Target>;
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
## Parameters
|
|
|
|
|
2024-03-25 13:03:57 +00:00
|
|
|
<table><thead><tr><th>
|
2022-08-06 14:49:20 +00:00
|
|
|
|
2024-03-25 13:03:57 +00:00
|
|
|
Parameter
|
|
|
|
|
|
|
|
</th><th>
|
|
|
|
|
|
|
|
Type
|
|
|
|
|
|
|
|
</th><th>
|
|
|
|
|
|
|
|
Description
|
|
|
|
|
|
|
|
</th></tr></thead>
|
|
|
|
<tbody><tr><td>
|
|
|
|
|
|
|
|
predicate
|
|
|
|
|
|
|
|
</td><td>
|
|
|
|
|
|
|
|
(x: [Target](./puppeteer.target.md)) => boolean \| Promise<boolean>
|
|
|
|
|
|
|
|
</td><td>
|
|
|
|
|
|
|
|
</td></tr>
|
|
|
|
<tr><td>
|
|
|
|
|
|
|
|
options
|
|
|
|
|
|
|
|
</td><td>
|
|
|
|
|
|
|
|
[WaitForTargetOptions](./puppeteer.waitfortargetoptions.md)
|
|
|
|
|
|
|
|
</td><td>
|
|
|
|
|
|
|
|
_(Optional)_
|
|
|
|
|
|
|
|
</td></tr>
|
|
|
|
</tbody></table>
|
2022-08-06 14:49:20 +00:00
|
|
|
**Returns:**
|
|
|
|
|
|
|
|
Promise<[Target](./puppeteer.target.md)>
|
|
|
|
|
|
|
|
## Example
|
|
|
|
|
2023-09-19 13:03:19 +00:00
|
|
|
Finding a target for a page opened via `window.open`:
|
2022-08-06 14:49:20 +00:00
|
|
|
|
|
|
|
```ts
|
|
|
|
await page.evaluate(() => window.open('https://www.example.com/'));
|
|
|
|
const newWindowTarget = await browser.waitForTarget(
|
|
|
|
target => target.url() === 'https://www.example.com/'
|
|
|
|
);
|
|
|
|
```
|