puppeteer/website/versioned_docs/version-21.9.0/api/puppeteer.jshandle.md
release-please[bot] d57b1044f2
chore: release main (#11744)
Co-authored-by: release-please[bot] <55107282+release-please[bot]@users.noreply.github.com>
2024-01-24 13:53:06 +00:00

4.3 KiB

sidebar_label
JSHandle

JSHandle class

Represents a reference to a JavaScript object. Instances can be created using Page.evaluateHandle().

Handles prevent the referenced JavaScript object from being garbage-collected unless the handle is purposely disposed. JSHandles are auto-disposed when their associated frame is navigated away or the parent context gets destroyed.

Handles can be used as arguments for any evaluation function such as Page.$eval(), Page.evaluate(), and Page.evaluateHandle(). They are resolved to their referenced object.

Signature:

export declare abstract 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);

Properties

Property Modifiers Type Description
_ optional T Used for nominally typing JSHandle.
move () => this

Methods

Method Modifiers Description
asElement Either null or the handle itself if the handle is an instance of ElementHandle.
dispose Releases the object referenced by the handle for garbage collection.
evaluate Evaluates the given function with the current handle as its first argument.
evaluateHandle Evaluates the given function with the current handle as its first argument.
getProperties Gets a map of handles representing the properties of the current handle.
getProperty Fetches a single property from the referenced object.
getProperty
jsonValue A vanilla object representing the serializable portions of the referenced object.
remoteObject Provides access to the Protocol.Runtime.RemoteObject backing this handle.
toString Returns a string representation of the JSHandle.