CSS Basic Patterns
CSS works by associating rules with HTML elements. These rules govern how the content of specified elements should be displayed. A CSS rule contains two parts: a selector and a declaration.
Selectors indicate which element the rule applies to. The same rule can apply to more than one element if you separate the element names with commas.
Declarations indicate how the elements referred to in the selector should be styled. Declarations are split into two parts (a property and a value), and are separated by a column.
👉 CSS Properties Affect how elements are displayed
CSS declarations sit inside curly brackets and each is made up of two parts: a property and a value, separated by a colon. You can specify several properties in one declaration, each separated by a semi-colon.
Properties indicate the aspects of the element you want to change. For example, color, font, width, height and border.
Values specify the settings you want to use for the chosen properties. For example, if you want to specify a color property then the value is the color you want the text in these elements to be.
Connecting CSS and HTML
You have two choices here, a link
tag and a style
tag. I'll gloss over style
because I don't want you to use it, but I want you to know it's there.
See the style
tag in the head? This allows you to write CSS directly in an HTML document. Anything inside in the style
tag will be read as CSS and applied to the whole document. This can be useful to rapidly test something out, but in reality you should really never need to use style
tags.
Rather, what we want is to have an HTML document and a separate CSS document that is loaded by the HTML document. This is useful because we get to keep all the content (HTML) and the styling (CSS) separate. This is called separation of concerns, and it's useful in many ways with programming. The idea is that is that you use each file to focus on doing one thing and doing it well. Where possible, it's best to separate things so you have many small files instead of a few big ones. Here, we want to separate our CSS and our HTML into different pages.
the index.html file:
Our style.css file (located in the same folder as the index.html file)
The key here is the <link rel="stylesheet" href="./style.css" />
. Let's break it down. A link tag is nearly always found in the head
and links another file to that HTML document. Nearly always (99.9% of the time), it's to a stylesheet
, hence the rel="stylesheet"
. The href
is where that other file is located. It refers to the file name. In this case, we have a file called style.css
and it is located in the same folder as the index.html
file, which is what the ./
part of the ./style.css
means. You could also write it as "style.css"
if it's in the same directory, it also means it's located in the same folder, but I wanted you to see the ./
because you'll see it everywhere. We'll cover how it works later when we start working more with the terminal.
When to use the Cascade
Before I told you to use the cascade as little as possible, but I did want to share with you when it can be useful to use. Imagine we have the following three buttons:
These buttons are relatively similar and differ only in colors but the spacing and text styling are all the same. It'd be nice if we could write the common styles in one rule and then overrule just the colors. The Cascade can be used.
Since those classes come lower on the page, they "win" on the properties that they conflict with, and thus we only overwrite the things we want. Why is this better? Imagine later you want to change the text to be smaller and the border to be thinner. Now instead of having to change the style for each button, you change it once in their common class, .ex-btn
and that affects all of them! This principle is generally called DRY which stands for "don't repeat yourself", meaning if you can have one place for common code or rules, it's better to do that than have it in 50 different places. While having three copies of the same rules doesn't seem like a big deal, many websites will have 10+ sorts of buttons and it quickly becomes impossible to manage.
Last updated