This is an experimental technology
Check the Browser compatibility table carefully before using this in production.
The :has()
CSS pseudo-class represents an element if any of the selectors passed as parameters (relative to the :scope
of the given element), match at least one element.
The :has()
pseudo-class takes a selector list as an argument. In the current specification :has
is not marked as part of the live selector profile, which means it can not be used within stylesheets; only with functions like document.querySelector()
.
/* Selects any <a>, as long as it has an <img> element directly inside it */ /* Note that this is not supported in any browser yet */ /* It also isn't intended to work in stylesheets */ var test = document.querySelector('a:has(> img)');
:has( <relative-selector-list> )where
<relative-selector-list> = <relative-selector>#where
<relative-selector> = <combinator>? <complex-selector>where
<combinator> = '>' | '+' | '~' | [ '||' ]
<complex-selector> = <compound-selector> [ <combinator>? <compound-selector> ]*where
<compound-selector> = [ <type-selector>? <subclass-selector>* [ <pseudo-element-selector> <pseudo-class-selector>* ]* ]!where
<type-selector> = <wq-name> | <ns-prefix>? '*'
<subclass-selector> = <id-selector> | <class-selector> | <attribute-selector> | <pseudo-class-selector>
<pseudo-element-selector> = ':' <pseudo-class-selector>
<pseudo-class-selector> = ':' <ident-token> | ':' <function-token> <any-value> ')'where
<wq-name> = <ns-prefix>? <ident-token>
<ns-prefix> = [ <ident-token> | '*' ]? |
<id-selector> = <hash-token>
<class-selector> = '.' <ident-token>
<attribute-selector> = '[' <wq-name> ']' | '[' <wq-name> <attr-matcher> [ <string-token> | <ident-token> ] <attr-modifier>? ']'where
<attr-matcher> = [ '~' | | | '^' | '$' | '*' ]? '='
<attr-modifier> = i
The following selector matches only <a>
elements that directly contain an <img>
child:
a:has(> img)
The following selector matches <h1>
elements only if they have a <p>
element directly following them:
h1:has(+ p)
Specification | Status | Comment |
---|---|---|
Selectors Level 4 The definition of ':has()' in that specification. | Working Draft | Initial definition |
Desktop | ||||||
---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | |
Basic support | No | No | No
|
No | No | No |
Mobile | |||||||
---|---|---|---|---|---|---|---|
Android webview | Chrome for Android | Edge Mobile | Firefox for Android | Opera for Android | iOS Safari | Samsung Internet | |
Basic support | No | No | No | No
|
No | No | No |
© 2005–2018 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/CSS/:has