5 CSS Practices To Avoid as a Web Developer
Updated: February 12, 2022•2 min read
data:image/s3,"s3://crabby-images/58814/5881408158b5ec0bb8b756830b3d72db0ee7959f" alt="5 CSS Practices To Avoid as a Web Developer"
1. Using the Same Rule Repetitively
A lot of beginners use repetitive rules for each element. If you want to create a rule for multiple elements, use a class attribute instead.
data:image/s3,"s3://crabby-images/5431b/5431bafab2ef7a521347254e2548d0ce7d612d78" alt="rewrite css meme GTA ah shit here we go again"
Do not do this:
#intro1 {color: #3498db;font-size: 10px;font-weight: bold;}header {color: #3498db;font-size: 20px;background-color: green;}#banner {color: #3498db;font-size: 30px;background-image: url(images/static.jpg);}
You can use:
.blue {color: #3498db;}
2. Shoving everything into one CSS file
Having a 3500 line CSS file is NOT the way to go. Even if you minify at a later date. You should start separating them into the 'views' or 'components' when you are working on a bigger project.
3. Naming your CSS selectors unnecessarily descriptive
'.sqaured-yellow-border-card' when '.card' will be suffice
4. !important this, !important that, !important !important
People who know how to write CSS never use these.
data:image/s3,"s3://crabby-images/6f5c7/6f5c77045cb90364b7016308631612ef43b92de3" alt="css important meme bad practice"
5. Set Margins or Padding and Then Reset Them
I often see people set margins or padding for all elements and then reset them for the first or last element. I don’t know why they use two rules when you can get by with one. It’s much easier to set margins and padding for all the required elements at once.
data:image/s3,"s3://crabby-images/947ca/947cab53310cc4691cce44a48d75b40cc1445141" alt="css box model margin padding meme"
Use one of the following for simpler and more concise CSS: nth-child
/nth-of-type
selectors, the :not()
pseudo-class, or the adjacent sibling combinator better known as +
.
Do not do this:
.item {margin-right: 1.6rem;}.item:last-child {margin-right: 0;}
You can use:
.item:not(:last-child) {margin-right: 1.6rem;}
Or
.item:nth-child(n + 2) {margin-left: 1.6rem;}
Or
.item + .item {margin-left: 1.6rem;}