Skip to content

Latest commit

 

History

History
302 lines (214 loc) · 9.61 KB

README.md

File metadata and controls

302 lines (214 loc) · 9.61 KB

Lesson 3 - Advanced CSS

Overview

Last week we learned a bit about Cascading Style Sheets (CSS for short). Today we're going to dig back in and learn some advanced CSS tactics to really make our page look awesome!

Recap

Last week we learned about a few things...

Selectors - Classes, IDs, and parent-child relationships

Declarations

Box Model

In HTML, every element is a rectangular box. Every box a height and a width that defines how big it is and how much space it will take up on the page.

If we want to make an image on our page 500px wide and 400px high, we could do the following:

img {
	height: 400px;
	width: 500px;
}

However, that isn't the only thing that defines how our image fits on the page because every element is surrounded by three more things: padding, border, and margin. Understanding how your padding, borders, and margins work is essential to making sure that your elements look as expected.

To help us understand this, we have this diagram:

The Box Model

The "border" is the edge of your box. Padding controls how close things inside the box can be to the border and Margin controls how close things outside the box can be to the border.

Let's see how this works in practice...

No margin, padding, or border

If you look at the first image on the page, you'll notice how it currently has no margin, padding, or border. As a result, it's pushed up against the left side of the page with no spacing.

Let's add some padding to the page to indent the image a little bit.

img {
  width: 50%;
  padding-left: 10px;
}

Image with padding

Now let's see what happens when we change that padding to a margin.

img {
  width: 50%;
  margin-left: 10px;
}

Image with margin

Nothing?! Wait a second... let's do some detective work. Let's change the color of the background for this element to see if there is any invisible spacing.

img {
  width: 50%;
  margin-left: 10px;
	background-color: tomato; 
}

Image with margin and color

Hmm... that didn't seem to do anything. Let's change from margin back to padding?

img {
  width: 50%;
  padding-left: 10px;
	background-color: tomato; 
}

Image with padding and color

Aha! When you use padding there is space between the left edge of the element and the picture itself.

Let's see what this looks like when we add a margin and a border.

img {
  width: 50%;
  padding-left: 10px;
  margin-left: 10px;
  border-left: 5px solid dimgray; 
  background-color: tomato;
}

Image with padding margin and color

You can see, the border color sits between the padding and the margin. If you're ever having trouble positioning your elements, make sure to check all 3: margin, padding, and border.

Float

Sometimes you'll want to move things around on the screen. Maybe you want to have the pictures on the right side of the screen and the descriptions on the left. Using float is a great way to make that happen.

Let's float our pictures to the right and our text to the left.

img {
  float: right;
  width: 50%;
  margin-left: 10px;
}

Image floating to the right

Whoa! Everything moved. Before we fix things, let's try to understand why that happened.

When floating an image, it is going to float all the way to the edge of its parent container. Because I applied float directly to ALL image tags on our page, the float looked to see what the parent container was and saw that it was <body> so it moved the images to the right edge of the body of the page.

When floating an image, the other elements will begin to line up around it within the natural flow of the page.

Float Right

However, since everything got pushed up the page, our descriptions of the pictures no longer match up with the pictures themselves.

We can fix this!

Let's decide how we want this to look. Probably something like this...

Floats

image thanks to Shay Howe

We are going to have our top section stretch across the screen while the middle section is split into two columns. The bottom will be all one section.

To do that, we're going to wrap our pictures and their caption paragraphs in two different divs

<div id="first-picture"> 
	<p>Today I took the dogs to the park and <strong>we had a great time!</strong></p>
	<img src="http://f.cl.ly/items/2f473l1d233S0S1k3J3d/dogs-playing.jpg">
</div>
    
<div id="second-picture">
	<p>After the dogs played with their friends <em>we took a walk around the track together.</em></p>
	<img src="http://f.cl.ly/items/0o0T0V0g261C1R0I022z/walking-the-track.jpg">
</div>
  
<div id="summary"> 
	<!-- your bottom section goes here -->
#first-picture {
  height: 400px;
}
#first-picture p {
  float: left;
}
#second-picture {
  height: 400px
}
#second-picture p {
  float: left;
}
#summary {
  clear: both
}

Pictures with their captions to the left

Bonus #1: What happens if you don't set a height?

Bonus #2: how would you go about cleaning up this messy code?

This can be messy. There are a lot of weird rules to how floats work and we don't have time to go over all of them but you can read more here.

Position

Beyond just floating elements, you can also position them with the position property.

CSS gives you five different options for using position: static relative absolute fixed and inherit

The default is static which is what gets set even if you don't bother to set any position. We'll talk about two others today, absolute and relative.

Let's start by creating a label that we're going to place on top of our image that we've floated to the right.

 <h1>A day at the dog park</h1>
    
    <div id="cool"> COOL! </div>
    
    <div id="first-picture"> 
#cool {
  color: white;
  font-size: 3em; 
}

Cool story

This is what it looks like as a static div.

Now let's give it an absolute position and make it display on top of our image.

#cool {
  position: absolute;
  left: 520px;
  top: 300px;
  color: white;
  font-size: 3em; 
}

Cooler story

Hmm... what would happen if we changed that absolute to "relative"

#cool {
  position: relative;
  left: 520px;
  top: 300px;
  color: white;
  font-size: 3em; 
}

Coolest story

It moved! But why? Let's see what happens if we move the div to a different place in the HTML file...

We'll move it to just before the div that contains the second picture.

    </div>
    
    <div id="cool"> COOL! </div>
    
    <div id="second-picture">

Coolest story

It moved down to just below the second picture.

Hmm... now what would happen if we changed the position back to absolute?

#cool {
  position: absolute;
  left: 520px;
  top: 300px;
  color: white;
  font-size: 3em; 
}

Whoa!

It went back up to the first picture! You see, when you set your position as absolute, CSS doesn't care where your HTML tag is because it's going to put the block absolutely where you tell it to go. When you use relative it puts it relative to the block listed right before it.

In this case, our left and top position measurements were being taken relative to the h1 in our body and then, after moving it, relative to our first-picture div.

Transitions

At the end of last week we learned how to do a transition when you hover over a li. Let's try making that cooler by experimenting with some modifications...

li:hover {
    background-color: burlywood;
    transition: background-color 5s;
}

You can do more than one transition at once too!

li:hover {
    background-color: burlywood;
    color: whitesmoke !important;
    transition: background-color 2s, color 2s;
}

Bonus: What does the !important do? What would happen without it?

Play around! Used wisely, transition effects can help create a delightful webpage for your readers.

Summary

Thanks! Next week we'll start digging into Javascript and some other cool things.

The Pen I used today.