Disallow invalid properties.
CSS has a defined set of known properties that are expected to have specific values. While CSS may parse correctly, that doesn't mean that the properties are correctly matched with their values. For example, the following is syntactically valid CSS code:
a {
display: black;
}
The property display
doesn't accept a color for its value, so while this code will parse without error, it's still invalid CSS.
Similarly, as long as a property name is syntactically valid, it will parse without error even if it's not a known property. For example:
a {
ccolor: black;
}
Here, ccolor
is a syntactically valid identifier even though it will be ignored by browsers. Such errors are often caused by typos.
This rule warns when it finds a CSS property that doesn't exist or a value that doesn't match with the property name in the CSS specification (custom properties such as --my-color
are ignored). The property data is provided via the CSSTree project.
Examples of incorrect code:
a {
display: black;
ccolor: black;
}
body {
overflow: 100%;
bg: red;
}
This rule uses the lexer from CSSTree, which does not support validation of property values that contain variable references (i.e., var(--bg-color)
). The lexer throws an error when it comes across a variable reference, and rather than displaying that error, this rule ignores it. This unfortunately means that this rule cannot properly validate properties values that contain variable references. We'll continue to work towards a solution for this.
If you aren't concerned with invalid properties, then you can safely disable this rule.