Skip to content

Week 3_2(en): CSS Rule Structure and Selectors

njs03332 edited this page Jul 23, 2018 · 10 revisions

CSS Rule Structure and Selectors

Now let's learn the syntax of CSS!

CSS Rule Structure

css rule structure
This is how a typical CSS rule looks like.

  • Selector: indicates the part we are going to apply the style to
  • Declaration Block: within the {}, specify how we want to style the part we selected
  • Declaration: consisted of property and its value in the form of property: value;
  • We can have as many declarations inside a rule as we like.

Different Types of Selectors

CSS can select HTML elements by tag, class, or ID.
Let's learn about each of them. 1. Tag Selector

As we did earlier, we can use a tag name as a selector to apply the style to all the elements of that name on our page.
We already have a rule for the <h1> tag. Let's modify the rule and add another one for the <p> tag.

h1 {
  color: red;
  font-size: 30px;
  text-align: center;
}

p {
  font-size: 20px;
  font-family: Arial;
}

You will see that the rule is applied to every <p> element.

2. Class Selector

CSS is not limited to selecting elements by tag name.
HTML elements can have more than just a tag name. They can also have attributes!
One common element is the class attribute, which we used last time.
We've learned that the class attribute can be used to style our page in a consistent way.
Let's add the following code to our blog.css file.

.south-korea {
  text-transform: uppercase;
  color: blueviolet;
}

To select an HTML element by its class, a period must come in front of the class name.

It is possible to add more than one class name to an HTML element's class attribute.
For example, let's say we want to make the title of our article darkgreen and bold.
We can add two rules like below.

.darkgreen {
  color: darkgreen;
}

.bold {
  font-weight: bold;
}

Then, we can include both of these classes to a single element.

<h2 class="darkgreen bold">...</h2>

Like this, we can add multiple classes to an element's class attribute by separating them with a space.
This prevents us from writing a custom class for every style combination needed, and enables us to mix and match CSS classes to create many unique styles.

3. ID Selector

We can style a specific element uniquely(regardless of classes applied to the element) by using an id attribute.
While classes are meant to be reused over many elements, an ID is meant to style only one element.
Let's add an id attribute to our <p> tag in the <footer>.

<p id="corp-name">&copy; YURI Corp. </p>

Then let's add the following rule to our .css file.

#corp-name {
  font-family: cursive;
  color: rebeccapurple;
}

To select an element by its id attribute, we need to prepend the id name with a hashtag.

Specificity

Specificity is the order by which the browser decides which CSS styles will be displayed when 2 or more styles are competing with one another.
IDs are more specific than classes, and classes are more specific than tags.
For example, let's add a class attribute to our corporation name like below.

<p id="corp-name" class="corp-name">

Then let's try adding color: grey; to p rule.
Also, let's add the following rule.

.corp-name {
  color: red;
}

You will notice that the corporation name has not changed to grey nor red.
This is because the browser selects the more specific rule, which is the rule specified by the ID selector in this case.
Let's try erasing the id attribute of the <p> tag temporarily.
Now you can see the corporation name in red, which means the class selector is more specific than the tag selector.

Note: A best practice is to style elements while using the lowest degree of specificity, so that if an element needs a new style, it is easy to override using a more specific selector.
To make styles easy to edit, style with a tag selector if possible. If not, add a class selector. If that is not specific enough, then consider using an ID selector.

Chaining Selectors

Clone this wiki locally