d0c4291995
Closes #8639
5.6 KiB
5.6 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() | ||
remoteObject() | Provides access to [Protocol.Runtime.RemoteObject](https://chromedevtools.github.io/devtools-protocol/tot/Runtime/#type-RemoteObject) backing this JSHandle. | |
toString() | Returns a string representation of the JSHandle. |