Package Exports
- stylelint-plugin-defensive-css
- stylelint-plugin-defensive-css/src/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (stylelint-plugin-defensive-css) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
π¦ Stylelint Plugin Defensive CSS
A Stylelint plugin to enforce defensive CSS best practices.
Getting Started
Before getting started with the plugin, you must first have Stylelint version 14.0.0 or greater installed
To get started using the plugin, it must first be installed.
npm i stylelint-plugin-defensive-css --save-dev
yarn add stylelint-plugin-defensive-css --dev
With the plugin installed, the rule(s) can be added to the project's Stylelint configuration.
{
"plugins": ["stylelint-plugin-defensive-css"],
"rules": {
"plugin/use-defensive-css": [
true,
{ "severity": "warning" }
]
}
}
Rules / Options
The plugin provides multiple rules that can be toggled on and off as needed.
Background Repeat
Oftentimes, when using a large image as a background, we tend to forget to account for the case when the design is viewed on a large screen. That background will repeat by default.
Enable this rule in order to prevent unintentional repeating background.
{
"rules": {
"plugin/use-defensive-css": [
true,
{ ..., "background-repeat": true }
]
}
}
β Passing Examples
div {
background: url('some-image.jpg') repeat black top center;
}
div {
background: url('some-image.jpg') black top center;
background-repeat: no-repeat;
}
β Failing Examples
div {
background: url('some-image.jpg') black top center;
}
div {
background-image: url('some-image.jpg');
}
Custom Property Fallbacks
CSS variables are gaining more and more usage in web design. There is a method that we can apply to use them in a way that doesnβt break the experience, in case the CSS variable value was empty for some reason.
Enable this rule in order to require fallbacks values for custom properties.
{
"rules": {
"plugin/use-defensive-css": [
true,
{ ..., "custom-property-fallbacks": true }
]
}
}
β Passing Examples
div {
color: var(--color-primary, #000);
}
β Failing Examples
div {
color: var(--color-primary);
}
Flex Wrapping
CSS flexbox is one of the most useful CSS layout features nowadays. Itβs tempting to add display: flex
to a wrapper and have the child items ordered next to each other. The thing is when there is not enough space, those child items wonβt wrap into a new line by default. We need to change that behavior with flex-wrap: wrap
.
Enable this rule in order to require all flex rows to have a flex-wrap value.
{
"rules": {
"plugin/use-defensive-css": [
true,
{ ..., "flex-wrapping": true }
]
}
}
β Passing Examples
div {
display: flex;
flex-wrap: wrap;
}
div {
display: flex;
flex-direction: row-reverse;
flex-wrap: wrap-reverse;
}
β Failing Examples
div {
display: flex;
}
div {
display: flex;
flex-direction: row;
}
Vendor Prefix Grouping
It's not recommended to group selectors that are meant to work with different browsers. For example, styling an input's placeholder needs multiple selectors per the browser. If we group the selectors, the entire rule will be invalid, according to w3c.
Enable this rule in order to require all vendor-prefixed selectors to be split into their own rules.
{
"rules": {
"plugin/use-defensive-css": [
true,
{ ..., "vendor-prefix-grouping": true }
]
}
}
β Passing Examples
input::-webkit-input-placeholder {
color: #222;
}
input::-moz-placeholder {
color: #222;
}
β Failing Examples
input::-webkit-input-placeholder,
input::-moz-placeholder {
color: #222;
}