mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
5ff205dc8b
* fix: extends `ElementHandle` to `Node`s (#8552)
5.3 KiB
5.3 KiB
sidebar_label |
---|
JSHandle |
JSHandle class
Represents an in-page JavaScript object. JSHandles can be created with the page.evaluateHandle method.
Signature:
export declare class JSHandle<T = unknown>
Remarks
The constructor for this class is marked as internal. Third-party code should not call the constructor directly or create subclasses that extend the JSHandle
class.
Example
const windowHandle = await page.evaluateHandle(() => window);
JSHandle prevents the referenced JavaScript object from being garbage-collected unless the handle is disposed. JSHandles are auto- disposed when their origin frame gets navigated or the parent context gets destroyed.
JSHandle instances can be used as arguments for Page.$eval(), Page.evaluate(), and Page.evaluateHandle().
Properties
Property | Modifiers | Type | Description |
---|---|---|---|
[__JSHandleSymbol]? | T | (Optional) Used for nominally typing JSHandle. |
Methods
Method | Modifiers | Description |
---|---|---|
asElement() | ||
dispose() | Stops referencing the element handle, and resolves when the object handle is successfully disposed of. | |
evaluate(pageFunction, args) | This method passes this handle as the first argument to pageFunction . If pageFunction returns a Promise, then handle.evaluate would wait for the promise to resolve and return its value. |
|
evaluateHandle(pageFunction, args) | This method passes this handle as the first argument to pageFunction . |
|
executionContext() | Returns the execution context the handle belongs to. | |
getProperties() | The method returns a map with property names as keys and JSHandle instances for the property values. | |
getProperty(propertyName) | Fetches a single property from the referenced object. | |
getProperty(propertyName) | ||
jsonValue() | ||
toString() | Returns a string representation of the JSHandle. |