A keyword representing either the type of the attribute's value, or its unit, as in HTML some attributes have implicit units. If the use of <type-or-unit>
as a value for the given attribute is invalid, the attr()
expression will be invalid too. If omitted, it defaults to string
. The list of valid values are:
string
-
The attribute value is treated as a CSS <string>
. It is NOT reparsed, and in particular the characters are used as-is instead of CSS escapes being turned into different characters.
Default value: an empty string.
-
color
Experimental
-
The attribute value is parsed as a hash (3- or 6-value hash) or a keyword. It must be a valid CSS <string>
value. Leading and trailing spaces are stripped.
Default value: currentcolor
.
-
url
Experimental
-
The attribute value is parsed as a string that is used inside a CSS url()
function. Relative URL are resolved relatively to the original document, not relatively to the style sheet. Leading and trailing spaces are stripped.
Default value: the URL about:invalid
that points to a non-existent document with a generic error condition.
-
integer
Experimental
-
The attribute value is parsed as a CSS <integer>
. If it is not valid, that is not an integer or out of the range accepted by the CSS property, the default value is used. Leading and trailing spaces are stripped.
Default value: 0
, or, if 0
is not a valid value for the property, the property's minimum value.
-
number
Experimental
-
The attribute value is parsed as a CSS <number>
. If it is not valid, that is not a number or out of the range accepted by the CSS property, the default value is used. Leading and trailing spaces are stripped.
Default value: 0
, or, if 0
is not a valid value for the property, the property's minimum value.
-
length
Experimental
-
The attribute value is parsed as a CSS <length>
dimension, that is including the unit (e.g. 12.5em
). If it is not valid, that is not a length or out of the range accepted by the CSS property, the default value is used. If the given unit is a relative length, attr()
computes it to an absolute length. Leading and trailing spaces are stripped.
Default value: 0
, or, if 0
is not a valid value for the property, the property's minimum value.
-
em
, ex
, px
, rem
, vw
, vh
, vmin
, vmax
, mm
, cm
, in
, pt
, or pc
Experimental
-
The attribute value is parsed as a CSS <number>
, that is without the unit (e.g. 12.5
), and interpreted as a <length>
with the specified unit. If it is not valid, that is not a number or out of the range accepted by the CSS property, the default value is used. If the given unit is a relative length, attr()
computes it to an absolute length. Leading and trailing spaces are stripped.
Default value: 0
, or, if 0
is not a valid value for the property, the property's minimum value.
-
angle
Experimental
-
The attribute value is parsed as a CSS <angle>
dimension, that is including the unit (e.g. 30.5deg
). If it is not valid, that is not an angle or out of the range accepted by the CSS property, the default value is used. Leading and trailing spaces are stripped.
Default value: 0deg
, or, if 0deg
is not a valid value for the property, the property's minimum value.
-
deg
, grad
, rad
Experimental
-
The attribute value is parsed as a CSS <number>
, that is without the unit (e.g. 12.5
), and interpreted as an <angle>
with the specified unit. If it is not valid, that is not a number or out of the range accepted by the CSS property, the default value is used. Leading and trailing spaces are stripped.
Default value: 0deg
, or, if 0deg
is not a valid value for the property, the property's minimum value.
-
time
Experimental
-
The attribute value is parsed as a CSS <time>
dimension, that is including the unit (e.g. 30.5ms
). If it is not valid, that is not a time or out of the range accepted by the CSS property, the default value is used. Leading and trailing spaces are stripped.
Default value: 0s
, or, if 0s
is not a valid value for the property, the property's minimum value.
-
s
, ms
Experimental
-
The attribute value is parsed as a CSS <number>
, that is without the unit (e.g. 12.5
), and interpreted as an <time>
with the specified unit. If it is not valid, that is not a number or out of the range accepted by the CSS property, the default value is used. Leading and trailing spaces are stripped.
Default value: 0s
, or, if 0s
is not a valid value for the property, the property's minimum value.
-
frequency
Experimental
-
The attribute value is parsed as a CSS <frequency>
dimension, that is including the unit (e.g. 30.5kHz
). If it is not valid, that is not a frequency or out of the range accepted by the CSS property, the default value is used.
Default value: 0Hz
, or, if 0Hz
is not a valid value for the property, the property's minimum value.
-
Hz
, kHz
Experimental
-
The attribute value is parsed as a CSS <number>
, that is without the unit (e.g. 12.5
), and interpreted as a <frequency>
with the specified unit. If it is not valid, that is not a number or out of the range accepted by the CSS property, the default value is used. Leading and trailing spaces are stripped.
Default value: 0Hz
, or, if 0Hz
is not a valid value for the property, the property's minimum value.
-
%
Experimental
-
The attribute value is parsed as a CSS <number>
, that is without the unit (e.g. 12.5
), and interpreted as a <percentage>
. If it is not valid, that is not a number or out of the range accepted by the CSS property, the default value is used. If the given value is used as a length, attr()
computes it to an absolute length. Leading and trailing spaces are stripped.
Default value: 0%
, or, if 0%
is not a valid value for the property, the property's minimum value.