"use strict";(self.webpackChunkwebsite=self.webpackChunkwebsite||[]).push([[22029],{3905:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>m});var a=n(67294);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function l(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function o(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var l=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var p=a.createContext({}),u=function(e){var t=a.useContext(p),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},c=function(e){var t=u(e.components);return a.createElement(p.Provider,{value:t},e.children)},s={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},d=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,l=e.originalType,p=e.parentName,c=i(e,["components","mdxType","originalType","parentName"]),d=u(n),m=r,f=d["".concat(p,".").concat(m)]||d[m]||s[m]||l;return n?a.createElement(f,o(o({ref:t},c),{},{components:n})):a.createElement(f,o({ref:t},c))}));function m(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var l=n.length,o=new Array(l);o[0]=d;var i={};for(var p in t)hasOwnProperty.call(t,p)&&(i[p]=t[p]);i.originalType=e,i.mdxType="string"==typeof e?e:r,o[1]=i;for(var u=2;u{n.r(t),n.d(t,{assets:()=>p,contentTitle:()=>o,default:()=>s,frontMatter:()=>l,metadata:()=>i,toc:()=>u});var a=n(87462),r=(n(67294),n(3905));const l={sidebar_label:"ExecutionContext.evaluateHandle"},o="ExecutionContext.evaluateHandle() method",i={unversionedId:"api/puppeteer.executioncontext.evaluatehandle",id:"version-16.2.0/api/puppeteer.executioncontext.evaluatehandle",title:"ExecutionContext.evaluateHandle() method",description:"Evaluates the given function.",source:"@site/versioned_docs/version-16.2.0/api/puppeteer.executioncontext.evaluatehandle.md",sourceDirName:"api",slug:"/api/puppeteer.executioncontext.evaluatehandle",permalink:"/api/puppeteer.executioncontext.evaluatehandle",draft:!1,tags:[],version:"16.2.0",frontMatter:{sidebar_label:"ExecutionContext.evaluateHandle"},sidebar:"sidebar",previous:{title:"ExecutionContext.evaluate",permalink:"/api/puppeteer.executioncontext.evaluate"},next:{title:"ExecutionContext.frame",permalink:"/api/puppeteer.executioncontext.frame"}},p={},u=[{value:"Parameters",id:"parameters",level:2},{value:"Example 1",id:"example-1",level:2},{value:"Example 2",id:"example-2",level:2},{value:"Example 3",id:"example-3",level:2}],c={toc:u};function s(e){let{components:t,...n}=e;return(0,r.kt)("wrapper",(0,a.Z)({},c,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"executioncontextevaluatehandle-method"},"ExecutionContext.evaluateHandle() method"),(0,r.kt)("p",null,"Evaluates the given function."),(0,r.kt)("p",null,"Unlike ",(0,r.kt)("a",{parentName:"p",href:"/api/puppeteer.executioncontext.evaluate"},"evaluate"),", this method returns a handle to the result of the function."),(0,r.kt)("p",null,"This method may be better suited if the object cannot be serialized (e.g. ",(0,r.kt)("inlineCode",{parentName:"p"},"Map"),") and requires further manipulation."),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"Signature:")),(0,r.kt)("pre",null,(0,r.kt)("code",{parentName:"pre",className:"language-typescript"},"class ExecutionContext {\n evaluateHandle<\n Params extends unknown[],\n Func extends EvaluateFunc = EvaluateFunc\n >(\n pageFunction: Func | string,\n ...args: Params\n ): Promise>>>;\n}\n")),(0,r.kt)("h2",{id:"parameters"},"Parameters"),(0,r.kt)("table",null,(0,r.kt)("thead",{parentName:"table"},(0,r.kt)("tr",{parentName:"thead"},(0,r.kt)("th",{parentName:"tr",align:null},"Parameter"),(0,r.kt)("th",{parentName:"tr",align:null},"Type"),(0,r.kt)("th",{parentName:"tr",align:null},"Description"))),(0,r.kt)("tbody",{parentName:"table"},(0,r.kt)("tr",{parentName:"tbody"},(0,r.kt)("td",{parentName:"tr",align:null},"pageFunction"),(0,r.kt)("td",{parentName:"tr",align:null},"Func ","|"," string"),(0,r.kt)("td",{parentName:"tr",align:null},"The function to evaluate.")),(0,r.kt)("tr",{parentName:"tbody"},(0,r.kt)("td",{parentName:"tr",align:null},"args"),(0,r.kt)("td",{parentName:"tr",align:null},"Params"),(0,r.kt)("td",{parentName:"tr",align:null},"Additional arguments to pass into the function.")))),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"Returns:")),(0,r.kt)("p",null,"Promise","<",(0,r.kt)("a",{parentName:"p",href:"/api/puppeteer.handlefor"},"HandleFor"),"<","Awaited","<","ReturnType","<","Func",">",">",">",">"),(0,r.kt)("p",null,"A ",(0,r.kt)("a",{parentName:"p",href:"/api/puppeteer.jshandle"},"handle")," to the result of evaluating the function. If the result is a ",(0,r.kt)("inlineCode",{parentName:"p"},"Node"),", then this will return an ",(0,r.kt)("a",{parentName:"p",href:"/api/puppeteer.elementhandle"},"element handle"),"."),(0,r.kt)("h2",{id:"example-1"},"Example 1"),(0,r.kt)("pre",null,(0,r.kt)("code",{parentName:"pre",className:"language-ts"},"const context = await page.mainFrame().executionContext();\nconst handle: JSHandle = await context.evaluateHandle(() =>\n Promise.resolve(self)\n);\n")),(0,r.kt)("h2",{id:"example-2"},"Example 2"),(0,r.kt)("p",null,"A string can also be passed in instead of a function."),(0,r.kt)("pre",null,(0,r.kt)("code",{parentName:"pre",className:"language-ts"},"const handle: JSHandle = await context.evaluateHandle('1 + 2');\n")),(0,r.kt)("h2",{id:"example-3"},"Example 3"),(0,r.kt)("p",null,"Handles can also be passed as ",(0,r.kt)("inlineCode",{parentName:"p"},"args"),". They resolve to their referenced object:"),(0,r.kt)("pre",null,(0,r.kt)("code",{parentName:"pre",className:"language-ts"},"const bodyHandle: ElementHandle = await context.evaluateHandle(\n () => {\n return document.body;\n }\n);\nconst stringHandle: JSHandle = await context.evaluateHandle(\n body => body.innerHTML,\n body\n);\nconsole.log(await stringHandle.jsonValue()); // prints body's innerHTML\n// Always dispose your garbage! :)\nawait bodyHandle.dispose();\nawait stringHandle.dispose();\n")))}s.isMDXComponent=!0}}]);