--- sidebar_label: BrowserContext.waitForTarget --- # BrowserContext.waitForTarget() method This searches for a target in this specific browser context. #### Signature: ```typescript class BrowserContext { waitForTarget( predicate: (x: Target) => boolean | Promise, options?: { timeout?: number; } ): Promise; } ``` ## Parameters | Parameter | Type | Description | | --------- | ---------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | predicate | (x: [Target](./puppeteer.target.md)) => boolean \| Promise<boolean> | A function to be run for every target | | options | { timeout?: number; } | _(Optional)_ An object of options. Accepts a timeout, which is the maximum wait time in milliseconds. Pass 0 to disable the timeout. Defaults to 30 seconds. | **Returns:** Promise<[Target](./puppeteer.target.md)> Promise which resolves to the first target found that matches the `predicate` function. ## Example An example of finding a target for a page opened via `window.open`: ```ts await page.evaluate(() => window.open('https://www.example.com/')); const newWindowTarget = await browserContext.waitForTarget( target => target.url() === 'https://www.example.com/' ); ```