14 KiB
Puppeteer API
Table of Contents
- class: Browser
- class: Page
- page.addScriptTag(url)
- page.click(selector)
- page.close()
- page.evaluate(fun, ...args)
- page.evaluateOnInitialized(fun, ...args)
- page.focus(selector)
- page.frames()
- page.httpHeaders()
- page.injectFile(filePath)
- page.mainFrame()
- page.navigate(url, options)
- page.plainText()
- page.printToPDF(filePath[, options])
- page.screenshot([options])
- page.setContent(html)
- page.setHTTPHeaders(headers)
- page.setInPageCallback(name, callback)
- page.setRequestInterceptor(interceptor)
- page.setUserAgent(userAgent)
- page.setViewportSize(size)
- page.title()
- page.type(text)
- page.uploadFile(selector, ...filePaths)
- page.url()
- page.userAgent()
- page.viewportSize()
- page.waitFor(selector)
- class: Dialog
- class: Frame
- class: Request
- class: Response
- class: InterceptedRequest
- class: Headers
- class: Body
class: Browser
Browser manages a browser instance, creating it with a predefined settings, opening and closing pages. Instantiating Browser class does not necessarily result in launching browser; the instance will be launched when the need will arise.
new Browser([options])
options
<Object> Set of configurable options to set on the browser. Can have the following fields:
browser.close()
Closes chromium application with all the pages (if any were opened). The browser object itself is considered to be disposed and could not be used anymore.
browser.closePage(page)
browser.newPage()
Create a new page in browser and returns a promise which gets resolved with a Page object.
browser.version()
class: Page
Page provides interface to interact with a tab in a browser. Pages are created by browser:
var browser = new Browser();
browser.newPage().then(page => {
...
});
Pages could be closed by page.close()
method.
page.addScriptTag(url)
url
<string> Url of a script to be added- returns: <Promise> Promise which resolves as the script gets added and loads.
page.click(selector)
selector
<string> A query selector of element to click. If there are multiple elements satisfying the selector, the first will be clicked.
page.close()
- returns: <Promise> Returns promise which resolves when page gets closed.
page.evaluate(fun, ...args)
fun
<function> Function to be evaluated in browser context...args
<...string> Arguments to pass tofun
- returns: <Promise<Object>> Promise which resolves to function return value
page.evaluateOnInitialized(fun, ...args)
fun
<function> Function to be evaluated in browser context...args
<...string> Arguments to pass tofun
- returns: <Promise<Object>> Promise which resolves to function
page.focus(selector)
selector
<string> A query selector of element to focus. If there are multiple elements satisfying the selector, the first will be focused.
page.frames()
page.httpHeaders()
- returns: <Object> Key-value set of additional http headers, which will be sent with every request.
page.injectFile(filePath)
filePath
<string> Path to the javascript file to be injected into page.- returns: <Promise> Promise which resolves when file gets successfully evaluated in page.
page.mainFrame()
page.navigate(url, options)
url
<string> URL to navigate page tooptions
<Object> Navigation parameters which might have the following properties:maxTime
<number> Maximum navigation time in milliseconds, defaults to 30 seconds.waitFor
<string> When to consider navigation succeeded, defaults toload
. Could be either:load
- consider navigation to be finished when theload
event is fired.networkidle
- consider navigation to be finished when the network activity stays "idle" for at leastnetworkIdleTimeout
ms.
networkIdleInflight
<number> Maximum amount of inflight requests which are considered "idle". Takes effect only withwaitFor: 'networkidle'
parameter.networkIdleTimeout
<number> A timeout to wait before completing navigation. Takes effect only withwaitFor: 'networkidle'
parameter.
- returns: <Promise<[Response]>> Promise which resolves to the main resource response. In case of multiple redirects, the navigation will resolve with the response of the last redirect.
The page.navigate
will throw an error if:
- there's an SSL error (e.g. in case of self-signed certificates).
- target URL is invalid.
- the
maxTime
is exceeded during navigation.
page.plainText()
page.printToPDF(filePath[, options])
filePath
<string> The file path to save the image to. The screenshot type will be inferred from file extensionoptions
<Object> Options object which might have the following properties:- returns: <Promise> Promise which resolves when the PDF is saved.
page.screenshot([options])
options
<Object> Options object which might have the following properties:path
<string> The file path to save the image to. The screenshot type will be inferred from file extension.type
<string> Specify screenshot type, could be eitherjpeg
orpng
.quality
<number> The quality of the image, between 0-100. Not applicable to.png
images.fullPage
<boolean> When true, takes a screenshot of the full scrollable page.clip
<Object> An object which specifies clipping region of the page. Should have the following fields:
- returns: <Promise<Buffer>> Promise which resolves to buffer with captured screenshot
page.setContent(html)
html
<string> HTML markup to assign to the page.- returns: <Promise> Promise which resolves when the content is successfully assigned.
page.setHTTPHeaders(headers)
headers
<Object> Key-value set of additional http headers to be sent with every request.- returns: <Promise> Promise which resolves when additional headers are installed
page.setInPageCallback(name, callback)
name
<string> Name of the callback to be assigned on window objectcallback
<function> Callback function which will be called in node.js- returns: <Promise> Promise which resolves when callback is successfully initialized
page.setRequestInterceptor(interceptor)
interceptor
<function> Callback function which accepts a single argument of type <InterceptedRequest>.
page.setUserAgent(userAgent)
userAgent
<string> Specific user agent to use in this page- returns: <Promise> Promise which resolves when the user agent is set.
page.setViewportSize(size)
size
<Object> An object with two fields:- returns: <Promise> Promise which resolves when the dimensions are updated.
page.title()
page.type(text)
text
<string> A text to type into a focused element.
page.uploadFile(selector, ...filePaths)
selector
<string> A query selector to a file input...filePaths
<string> Sets the value of the file input these paths- returns: <Promise> Promise which resolves when the value is set.
page.url()
page.userAgent()
- returns: <string> Returns user agent.
page.viewportSize()
- returns: <Object> An object with two fields:
page.waitFor(selector)
selector
<string> A query selector to wait for on the page.
Wait for the selector
to appear in page. If at the moment of calling
the method the selector
already exists, the method will return
immediately.
Shortcut for page.mainFrame().waitFor(selector).
class: Dialog
dialog.accept([promptText])
promptText
<string> A text to enter in prompt. Does not cause any effects if the dialog type is not prompt.
dialog.dismiss()
dialog.message()
class: Frame
frame.childFrames()
frame.evaluate(fun, ...args)
fun
<function> Function to be evaluated in browser context...args
<Array<string>> Arguments to pass tofun
- returns: <Promise<Object>> Promise which resolves to function return value
frame.isDetached()
frame.isMainFrame()
frame.name()
frame.parentFrame()
frame.securityOrigin()
frame.url()
frame.waitFor(selector)
selector
<string> CSS selector of awaited element,- returns: <Promise> Promise which resolves when element specified by selector string is added to DOM.
class: Request
request.response()
class: Response
response.request()
class: InterceptedRequest
interceptedRequest.abort()
interceptedRequest.continue()
interceptedRequest.isHandled()
class: Headers
headers.append(name, value)
If there's already a header with name name
, the header gets overwritten.
headers.delete(name)
name
<string> Case-insensetive name of the header to be deleted. If there's no header with such name, the method does nothing.
headers.entries()
headers.get(name)
name
<string> Case-insensetive name of the header.- returns: <string> Header value of
null
, if there's no such header.
headers.has(name)
name
<string> Case-insensetive name of the header.- returns: <boolean> Returns
true
if the header with such name exists, orfalse
otherwise.
headers.keys()
headers.set(name, value)
If there's already a header with name name
, the header gets overwritten.