Skip to content

Latest commit

 

History

History
178 lines (126 loc) · 6.23 KB

README.md

File metadata and controls

178 lines (126 loc) · 6.23 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 300px wide and 200px high, we could do the following:

img {
	height: 200px;
	width: 300px;
}

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... First set the body's margin to 0 in the css box:

body {
  margin: 0;  
}

No margin, padding, or border

If you look at the 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 first add a border to the image:

img {
  width: 50%;
  border: 2px solid black;
}

No margin, padding, with border

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

img {
  width: 50%;
  border: 2px solid black;
  padding-left: 10px;
}

Image with padding

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

img {
  width: 50%;
  border: 2px solid black;  
  margin-left: 10px;
}

Image with margin

Now you can see that space is added outside the border of the image.

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

img {
  width: 50%;  
  border: 2px solid black;  
  padding-left: 10px;
  margin-left: 10px;
  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! The image mvoed to the right! 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.

Let's float the text to the left so that the picture is right next to it. We can do this by wrapping the content into a div and floating to the left:

<div>
    <p id="intro">Today, I'd like to share about my favorite season.</p>
    <p>There are four seasons in a year.</p>
    <ul>
        <li>spring</li>
        <li class="blue">summer</li>
        <li>fall</li>
        <li>winter</li>
    </ul>
    <p>My favorite season is summer, because I can go to the beach with my family.</p>
</div>

Here, we want to set the width to less than 50% because our img tag has a width of 50% and also some margin:

div {
  float: left;
  width: 40%;
}

Floats

Hmm.. but the paragraph with the link is now squeezed in between my content and the image. =(

We can fix this by allowing the paragraph to stretch across the whole page.

To do that, we have to tell the last paragraph tag to clear the float property. Let's add a class to the last paragraph and add a css property:

<p class="clearFloat">Click <a href="http://baytobeachlife.files.wordpress.com/2013/02/male-sealion3-by-chris-parsons.jpg">here</a> to see my favorite sea animal.</p>  
.clearFloat {
    clear: both;
}

Completed page with float left, right, and clear

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.

Summary

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

The Fiddle I used today.