mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
docs(api.md): add documentation on custom handlers (#8074)
This commit is contained in:
parent
213deb1921
commit
bc9ec323cc
1
.gitignore
vendored
1
.gitignore
vendored
@ -23,3 +23,4 @@ puppeteer.tgz
|
|||||||
docs-api-json/
|
docs-api-json/
|
||||||
docs-dist/
|
docs-dist/
|
||||||
website/docs
|
website/docs
|
||||||
|
docs/api.html
|
||||||
|
24
docs/api.md
24
docs/api.md
@ -414,6 +414,7 @@
|
|||||||
* [eventEmitter.removeAllListeners([event])](#eventemitterremovealllistenersevent)
|
* [eventEmitter.removeAllListeners([event])](#eventemitterremovealllistenersevent)
|
||||||
* [eventEmitter.removeListener(event, handler)](#eventemitterremovelistenerevent-handler)
|
* [eventEmitter.removeListener(event, handler)](#eventemitterremovelistenerevent-handler)
|
||||||
- [interface: CustomQueryHandler](#interface-customqueryhandler)
|
- [interface: CustomQueryHandler](#interface-customqueryhandler)
|
||||||
|
- [interface: Selector](#interface-selector)
|
||||||
<!-- GEN:stop -->
|
<!-- GEN:stop -->
|
||||||
|
|
||||||
<!-- prettier-ignore-end -->
|
<!-- prettier-ignore-end -->
|
||||||
@ -5525,6 +5526,26 @@ This method is identical to `off` and maintained for compatibility with Node's E
|
|||||||
|
|
||||||
Contains two functions `queryOne` and `queryAll` that can be [registered](#puppeteerregistercustomqueryhandlername-queryhandler) as alternative querying strategies. The functions `queryOne` and `queryAll` are executed in the page context. `queryOne` should take an `Element` and a selector string as argument and return a single `Element` or `null` if no element is found. `queryAll` takes the same arguments but should instead return a `NodeList<Element>` or `Array<Element>` with all the elements that match the given query selector.
|
Contains two functions `queryOne` and `queryAll` that can be [registered](#puppeteerregistercustomqueryhandlername-queryhandler) as alternative querying strategies. The functions `queryOne` and `queryAll` are executed in the page context. `queryOne` should take an `Element` and a selector string as argument and return a single `Element` or `null` if no element is found. `queryAll` takes the same arguments but should instead return a `NodeList<Element>` or `Array<Element>` with all the elements that match the given query selector.
|
||||||
|
|
||||||
|
### interface: Selector
|
||||||
|
|
||||||
|
A selector is a [string] for querying elements in the page.
|
||||||
|
The default behavior is to regard the string as a [CSS selector] and query using `querySelector` or `querySelectorAll`.
|
||||||
|
If a selector string contains a forward slash `/` the selector is instead regarded as custom selector where everything before the slash is the [custom handler](#puppeteerregistercustomqueryhandlername-queryhandler) name and everything after is the selector: `<handler>/<selector>`.
|
||||||
|
Puppeteer ships with two such custom handlers pre-registered:
|
||||||
|
|
||||||
|
- `aria/`: Queries the accessibilty tree for computed accessibility properties.
|
||||||
|
The selectors consist of an accessible name to query for and optionally
|
||||||
|
further aria attributes on the form `[<attribute>=<value>]`.
|
||||||
|
Currently, we only support the `name` and `role` attribute.
|
||||||
|
The following examples showcase how the syntax works wrt. querying:
|
||||||
|
|
||||||
|
- `title[role="heading"]` queries for elements with name 'title' and role 'heading'.
|
||||||
|
- `[role="img"]` queries for elements with role 'img' and any name.
|
||||||
|
- `label` queries for elements with name 'label' and any role.
|
||||||
|
- `[name=""][role="button"]` queries for elements with no name and role 'button'.
|
||||||
|
|
||||||
|
- `pierce`: Takes a [CSS selector] and queries the page using `querySelector` or `querySeletorAll` but pierces through shadow roots.
|
||||||
|
|
||||||
[axnode]: #accessibilitysnapshotoptions 'AXNode'
|
[axnode]: #accessibilitysnapshotoptions 'AXNode'
|
||||||
[accessibility]: #class-accessibility 'Accessibility'
|
[accessibility]: #class-accessibility 'Accessibility'
|
||||||
[array]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array 'Array'
|
[array]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array 'Array'
|
||||||
@ -5569,7 +5590,8 @@ Contains two functions `queryOne` and `queryAll` that can be [registered](#puppe
|
|||||||
[iterator]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols 'Iterator'
|
[iterator]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols 'Iterator'
|
||||||
[number]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Number_type 'Number'
|
[number]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Number_type 'Number'
|
||||||
[origin]: https://developer.mozilla.org/en-US/docs/Glossary/Origin 'Origin'
|
[origin]: https://developer.mozilla.org/en-US/docs/Glossary/Origin 'Origin'
|
||||||
[selector]: https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors 'selector'
|
[selector]: #interface-selector'Selector'
|
||||||
|
[css selector]: https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors
|
||||||
[stream.readable]: https://nodejs.org/api/stream.html#stream_class_stream_readable 'stream.Readable'
|
[stream.readable]: https://nodejs.org/api/stream.html#stream_class_stream_readable 'stream.Readable'
|
||||||
[string]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#String_type 'String'
|
[string]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#String_type 'String'
|
||||||
[symbol]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Symbol_type 'Symbol'
|
[symbol]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Symbol_type 'Symbol'
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
"prettier-fix": "prettier --write .",
|
"prettier-fix": "prettier --write .",
|
||||||
"lint": "npm run eslint && npm run build && npm run doc && npm run prettier",
|
"lint": "npm run eslint && npm run build && npm run doc && npm run prettier",
|
||||||
"doc": "node utils/doclint/cli.js",
|
"doc": "node utils/doclint/cli.js",
|
||||||
|
"generate-api-docs-for-testing": "commonmark docs/api.md > docs/api.html",
|
||||||
"clean-lib": "rimraf lib",
|
"clean-lib": "rimraf lib",
|
||||||
"build": "npm run tsc && npm run generate-d-ts",
|
"build": "npm run tsc && npm run generate-d-ts",
|
||||||
"tsc": "npm run clean-lib && tsc --version && npm run tsc-cjs && npm run tsc-esm",
|
"tsc": "npm run clean-lib && tsc --version && npm run tsc-cjs && npm run tsc-esm",
|
||||||
|
Loading…
Reference in New Issue
Block a user