code in one day: Html & css crash course
Brett Haymaker, JavaScript Developer & Instructor
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Introductions
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
- Who am I?
- Why am I here?
- What am I looking to take away from this course?
- I'll start us off
Course Trajectory
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
- Fundamentals of the Internet: Review
- HTML review / Why we use a text editor
- HTML lab
- CSS review
- CSS lab
- CSS positioning review
- CSS positioning lab
- File structure / Build a project together from scratch
- Discuss deployment strategies / options
If we have time:
- media queries
- transitions
- animations
Fundamentals of the internet
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
- The wires
- Montana
- Request / Response
- domain names / IPs
- The disappointing reality of the internet
Domain Anatomy
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/5f299/5f2993228a3de0621e4ed28785159bfa52280c37" alt=""
Front-end vs. Back-end
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/0868a/0868a8b9936724d244aa0e1ae42d9a984b225bf5" alt=""
Learning Objectives: HTML
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
-
Identify common HTML elements and write with correct
syntax -
Assign attributes to elements
-
Correctly indent content according to document
hierarchy -
Recognize name and purpose of HTML5 semantic
elements -
Build a basic static HTML webpage from scratch
html syntax
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
A tag is essentially an element or object that you will place on the page. These elements are represented by an opening tag and a closing tag.
data:image/s3,"s3://crabby-images/d89dd/d89dd5d1cc1ea093ffec95dde8f64b9d5fba94d2" alt=""
NEsted elements
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Elements can be nested inside of one another... We use indentation to visually communicate this nested hierarchy.
data:image/s3,"s3://crabby-images/46170/4617062c8a4ea17faf97daec04a31d99340582d7" alt=""
Page Structure
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
The main components of every HTML document...
data:image/s3,"s3://crabby-images/6b437/6b4373e7de09690221b704883e734ed39223e075" alt=""
- DOCTYPE
- html
- head
- body
Page elements
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/09cfa/09cfa70b0ad4b32878bcdba4ab72aca52a3e1f25" alt=""
data:image/s3,"s3://crabby-images/f7801/f78017153ba9bbc322fea49f4bcc7c2e0e848de1" alt=""
data:image/s3,"s3://crabby-images/20b70/20b7078cdcbbe29fa981692c0f073b785a93c95d" alt=""
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
MALFORMED HTML LAB
10 MINUTES
In the ugly/ directory in the class starter files
- Open the index.html file
- Identify the mistakes
- Leverage our text editors to help you find the errors
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Creating a Resume in html
30 MINUTES
- In a new directory/folder, create a new index.html
- Using the tags we have covered so far, create - to the best of your ability - a copy of your resume
Learning Objectives: css
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
-
Link external stylesheets to your web page.
-
Use CSS selectors to target elements for styling.
-
Style basic CSS properties of an element.
-
Set the box model properties to control the size of
elements. -
CSS Lab!
css: What is it?
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
CSS stands for Cascading Style Sheets. This is where we will tell page elements that we have added to our HTML document how they will appear - and in some cases, how they will behave.
Css syntax
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/db2a2/db2a2676c4047a0bc6d6c0472401526eaeec0ed7" alt=""
applying Css
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
We have three ways of applying CSS to our HTML elements
- internal stylesheet
- external stylesheet
- inline
- Let's apply some styles together in these various ways.
- Now you try.
Css selectors
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/f61ea/f61ea32af53727f65e791c9aba62f80cf05ced0c" alt=""
css specificity
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Specificity refers to how a selector, or a group of selectors, is ranked by the CSS language. While CSS is known for its cascading behavior, this same cascade can be broken and over-ridden.
Knowing how CSS determines and calculates specificity can help us craft our styles more efficiently and accurately. Take a look:
data:image/s3,"s3://crabby-images/f0fd1/f0fd19f2323de0c543c8d30c0eed24fe95bec02f" alt=""
css cascade vs. specificity
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/bf157/bf157b7005f8f899761e0ead58846237bf806f4d" alt=""
css Combinators
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/61734/61734afbbdd21051479d10d4a358a4899190edbe" alt=""
css short-hand properties vs. explicit
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/a7fd9/a7fd9ea84050d078b3246ec226d20c6901b7c33f" alt=""
The Box Model
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Every element in your web page is a rectangular box. This box consists of 4 distinct parts:
- the content
- the padding
- the border
- the margin
data:image/s3,"s3://crabby-images/e37ee/e37eee1deb5ec5c2a72dfadbbdd2902f6cb6dd85" alt=""
Margin vs. padding
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/2eeaa/2eeaadb86631e93a3372bb7fe3a39686c3c351e0" alt=""
data:image/s3,"s3://crabby-images/b421a/b421a2e2a1566e1278a21cf851abf29c4a18d3e4" alt=""
What's the difference? Experiment!
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
css lab
15 - 30 MINUTES
Using your resume .html file, experiment with the CSS properties we have covered thus far:
- Use at least 1 ID & 4 classes
- Combine selectors by using both the element tag name and the class name to achieve greater specificity
Learning Objectives: CSS part 2
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
-
Project Setup from scratch
-
Display Types
-
Positioning
-
Floats and clear
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
LET's BUILD TOGETHER...
Together, let's:
- Create a project folder on our Desktop
- In Sublime / Atom, open that folder
- Create an index.html file and a main.css file from within Sublime
- Create the basic structure of an html document
display types
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
The CSS display property has three main options, and it's important to know how those options alter the orientation and the flow of elements on the page.
data:image/s3,"s3://crabby-images/b3742/b374202e0bc2028829524a1ac126a4288ea3f792" alt=""
1. display: block;
2. display: inline;
3. display: inline-block;
data:image/s3,"s3://crabby-images/65eab/65eabffa3ca151b1feb4e1679c1cd5d34403cb2f" alt=""
data:image/s3,"s3://crabby-images/64001/64001e0c9097918be319f9fb51d6ef7f4ebf49e1" alt=""
positioning
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Positioning is intended to move an element outside it's normal flow on the page, whether that flow is inline, block, or inline-block.
data:image/s3,"s3://crabby-images/e10be/e10be35709ab458c2bd9c192d789a1409138c3cb" alt=""
positioning
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/8055d/8055d5e6e268ac5abc9416d503e86c7772482960" alt=""
positioning
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/668de/668de66013fdc1a1ef1bf01eda00d304d0b6ea33" alt=""
positioning
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/967a3/967a34993d9ab9a8c3d2437a5e6178b034e89a14" alt=""
Floats & clear
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Floats were created as a way for us to impose behavior on page elements that fall outside of the normal flow. By applying floats, we alter the normal flow of the document...
...an alteration that we need to restore to the document after we done floating elements. If we don't 'clear' a float - our page will behave in perplexing, unexpected ways.
floats & clear
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
data:image/s3,"s3://crabby-images/4503e/4503e7f7c0d2189423e41470a1db8842b3e56e1b" alt=""
We can add an additional div at the bottom of our floated elements
OR
we can take advantage of CSS psuedo-elements like :after & :before
Learning Objectives: Deploying a page
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
-
Netlify deployment
-
Other hosting platforms
-
Bluehost
-
Dreamhost
-
-
FTP / SSH
-
FileZilla
-
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Resources
HTML & CSS:
marksheet.io
learn.shayhowe.com
css-tricks.com/guides/beginner
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Upcoming courses
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
wrap up
Quick Survey:
Q&A
data:image/s3,"s3://crabby-images/e20f7/e20f7cea30b0112d3d2bc0cd03db6cb9803e17bd" alt=""
Thank you!
Contact information:
brett.haymaker@gmail.com
@BrettHaymaker
brett-haymaker.com
Code In One Day Bootcamp
By Brett Haymaker
Code In One Day Bootcamp
- 50