data:image/s3,"s3://crabby-images/dc651/dc651ec62cbe17affbb2f37c839fdfe7988f7e50" alt="Everything You Need to Know About CSS Units"
CSS
CSS (Cascading Style Sheets) is a stylesheet language used to describe the presentation of a document written in HTML. It is a core part of the web that lets you create stunning designs, interactive elements, and animations.
What you see below is CSS Zen Garden, a popular site that demonstrates the variety and flexibility of CSS, and how the same document can be represented in vastly different ways. All three pages have the same content, except they use different CSS.
data:image/s3,"s3://crabby-images/a5290/a5290da0b34ef39e67e78bbe5dfda5679ae6a2af" alt="CSS can alter the look and feel of the same layout"
Why Should I Learn CSS?#
Still, the question remains: why should I care about learning CSS? What's in it for me? Here are four reasons to help you decide whether you should invest your time in learning CSS:
- Enhanced user experience: One of the most compelling reasons for learning CSS is the enhanced user experience. You can use CSS animations, transitions, and effects to add visual appeal and interactivity. With CSS, you can create smooth transitions, image carousels, dropdown menus, and much more, making your websites more engaging and user-friendly.
- Responsiveness: As mobile usage surpassed desktop usage worldwide, it is crucial to make web applications responsive. CSS provides the means to create websites that adapt seamlessly to different screen sizes and devices, ensuring a great look on a wide variety of devices, such as desktops, laptops, tablets, and smartphones.
- Easy to learn: CSS is considered easy to learn due to its simpler syntax compared to other languages. This makes it a perfect choice for getting started in the world of web development.
- A core part of the web: If you are looking to get into frontend development, there is no way around CSS. It is a core part of the web, and even the simplest websites use it.
data:image/s3,"s3://crabby-images/dc651/dc651ec62cbe17affbb2f37c839fdfe7988f7e50" alt="Everything You Need to Know About CSS Units"
data:image/s3,"s3://crabby-images/9d67e/9d67e1584c8a06375cb397891f8619c04aea3ee1" alt="10 Best Practices for Improving Your CSS"
data:image/s3,"s3://crabby-images/25bde/25bdef8c534d53f957b0400c49fe615157a4b829" alt="How to Get Better Overview of Your CSS"
Show Me How CSS Works#
Let's take a look at a simple example to see how CSS works. In the following code, we have a .loader
class styled as a loading indicator using CSS borders and animations.
.loader {
width: 50px;
height: 50px;
border: 10px dotted #FCBA28;
border-radius: 100%;
animation: loading 1s linear infinite;
}
@keyframes loading {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
To style elements in CSS, we need to reference them using a query selector, such as their class. In this example, we reference a div
with a class of .loader
. Inside curly braces, we can style the element with CSS properties, consisting of name and value pairs:
width
andheight
: Thewidth
andheight
CSS properties are responsible for setting the dimensions of an element. In this example, they are set to 50 pixels.border
: This property sets a border around the element. In this example, it combines three other CSS properties:border-width
(10px),border-style
(dotted), andborder-color
(#FCBA28).border-radius
: Theborder-radius
property sets how rounded the corners should be.animation
: Theanimation
property can be used for defining animations in CSS. Just like for borders, this CSS property also combines multiple CSS properties into one:animation-name
(loading),animation-duration
(1s),animation-timing-function
(linear), andanimation-iteration-count
(infinite).transform
: Lastly, we can seetransform
rules inside the animation which can be defined by using the@keyframes
keyword. In this example, the element will be rotated using atransform
rule from 0 degrees to 360 degrees.
To better understand how these CSS rules work together, use the interactive example below. Changing the controls will affect the visuals of the loader.
{ "width": "50px", "height": "50px", "border-radius": "100%", "border-width": "10px", "animation-duration": "1s", "border-style": "dotted" }
Where Should I Start?#
If you are new to CSS, you should start with the basics. First, you need to familiarize yourself with the syntax and the different units that CSS has to offer.
data:image/s3,"s3://crabby-images/dc651/dc651ec62cbe17affbb2f37c839fdfe7988f7e50" alt="Everything You Need to Know About CSS Units"
You will need to know how CSS specificity works and how to construct different selectors that can be used to style elements. A fun game to practice CSS selectors is using the CSS Diner game. You will also need to be aware of how the box model works.
data:image/s3,"s3://crabby-images/48208/48208b80f799180865ad0aefcc66e2cb0a413933" alt="Representation of the box model"
The box model tells the browser the position and size of each element on the page. Each element can be surrounded by paddings (which will be part of the element), as well as a border. Elements can be spaced from each other using margins (which will not be shown visually).
Once you are familiar with the basics and you are comfortable with styling elements, you can start exploring more advanced concepts, such as responsive design and working with complex animations.
If you would like to learn more about CSS, you can find all of our latest tutorials below. Use the filters in the sidebar if you want to narrow down the results. Additionally, you can filter for CSS-related tutorials on our search page. I wish you good luck with learning CSS!
Keep on coding! π¨βπ»
data:image/s3,"s3://crabby-images/bf48e/bf48ef0eeaf5fda6157c1ab7e08c8c710f4bc3e3" alt="Introduction to Sass in Astro"
Introduction to Sass in Astro
data:image/s3,"s3://crabby-images/c1993/c1993263b31b08e2bb404b0c57c476a7fa463f12" alt="CSS Grid vs Flexbox - Which One to Use and Why?"
CSS Grid vs Flexbox - Which One to Use and Why?
data:image/s3,"s3://crabby-images/24862/248623441a0f858a872313560e215d3d7db2d55f" alt="How to Format Pages for Print in CSS"
How to Format Pages for Print in CSS
data:image/s3,"s3://crabby-images/4978b/4978be6dbbe9c50414949469d2ad3bb5fb0594bb" alt="How to Expand and Collapse Tables in HTML Using CSS"
How to Expand and Collapse Tables in HTML Using CSS
data:image/s3,"s3://crabby-images/61553/6155342d801504836a41b2786f2ff39ead496f27" alt="4 Different Ways to Align Footer to Bottom of Page in CSS"
4 Different Ways to Align Footer to Bottom of Page in CSS
data:image/s3,"s3://crabby-images/654a5/654a5c4b7d68f6e1ed7934c8bb363de10db28731" alt="Best Practices for Responsive User Interfaces Using CSS"
Best Practices for Responsive User Interfaces Using CSS
data:image/s3,"s3://crabby-images/7e20a/7e20a1c23b9e959bbd0beb19375dda9fe1d33fa7" alt="How to 3D Flip Images With CSS"
How to 3D Flip Images With CSS
data:image/s3,"s3://crabby-images/7bfd8/7bfd8b0081c61aa7608e2221b30734a75c9cc798" alt="How to Get Rid of Bullet Points in CSS"
How to Get Rid of Bullet Points in CSS
data:image/s3,"s3://crabby-images/7bfd8/7bfd8b0081c61aa7608e2221b30734a75c9cc798" alt="Exclude Any Class Name in CSS With This Selector"
Exclude Any Class Name in CSS With This Selector
data:image/s3,"s3://crabby-images/7bfd8/7bfd8b0081c61aa7608e2221b30734a75c9cc798" alt="How to Disable Text Selection in CSS Using One Rule"
How to Disable Text Selection in CSS Using One Rule
data:image/s3,"s3://crabby-images/628eb/628eb9cc2a7127a5ee6e93650a4b3f5411467897" alt="Change the Color of a Selected Text in CSS with One Rule"
Change the Color of a Selected Text in CSS with One Rule
data:image/s3,"s3://crabby-images/2607b/2607b2348db811189cdb532c66850e2e511f8bd0" alt="How to Quickly Add Line Numbers to HTML Textarea"
How to Quickly Add Line Numbers to HTML Textarea
data:image/s3,"s3://crabby-images/74c53/74c53fdb69fd171369c7c7c308900fbe2612ee09" alt="The State of CSS in 2021"
The State of CSS in 2021
data:image/s3,"s3://crabby-images/1f706/1f706ea0f887e693351f2f9e5a1202b38f085a48" alt="How to Automatically Number Headings with CSS"
How to Automatically Number Headings with CSS
data:image/s3,"s3://crabby-images/29135/291354e7ebd5b349a8d37cd111375e6dfe0ca398" alt="How to Make Pixel Art With Box Shadows"
How to Make Pixel Art With Box Shadows
data:image/s3,"s3://crabby-images/9e3f8/9e3f846b4e1096ef7561b8dbcbe771585a1e7336" alt="Get the Most out of CSS Grids with Chrome 87"
Get the Most out of CSS Grids with Chrome 87
data:image/s3,"s3://crabby-images/2f6ad/2f6adac4fd888fbe6417d78c4021932d6b88f722" alt="How to Create a Material Circle Loader in CSS"
How to Create a Material Circle Loader in CSS
data:image/s3,"s3://crabby-images/7240a/7240affbad3e8ede9bc27ded1f4e01d9b047b1cf" alt="Simple Ways to Fake Masonry in CSS"
Simple Ways to Fake Masonry in CSS
data:image/s3,"s3://crabby-images/dc651/dc651ec62cbe17affbb2f37c839fdfe7988f7e50" alt="Everything You Need to Know About CSS Units"
Everything You Need to Know About CSS Units
data:image/s3,"s3://crabby-images/f70ee/f70ee1fc45676e994dea86a9b6c4691c336beeac" alt="How to Easily Make Donut Charts With CSS Only"
How to Easily Make Donut Charts With CSS Only
data:image/s3,"s3://crabby-images/0e221/0e221113b90a01f48b9b07a6e097b66693126190" alt="How to Master Using Flexbox in CSS"
How to Master Using Flexbox in CSS
data:image/s3,"s3://crabby-images/fd043/fd0435920f32fd4c2a4898f750b95761e30f839b" alt="Mentoring"
Rocket Launch Your Career
Speed up your learning progress with our mentorship program. Join as a mentee to unlock the full potential of Webtips and get a personalized learning experience by experts to master the following frontend technologies:
Courses
data:image/s3,"s3://crabby-images/83c39/83c39eaed8df30300dca5bda3d1681a4428cb1ac" alt="CSS - The Complete Guide (including Flexbox, Grid and Sass)"
CSS - The Complete Guide (including Flexbox, Grid and Sass)
data:image/s3,"s3://crabby-images/58f7c/58f7c2b44afda6d91e8da9745b0f48a804c227e1" alt="The HTML & CSS Bootcamp"
The HTML & CSS Bootcamp
data:image/s3,"s3://crabby-images/5d142/5d142334601e601c1c6bad8523bad679262cd196" alt="The Creative HTML5 & CSS3 Course"