__ __ _ _____ _ _ _
\ \ / /__| |__ |_ _| _| |_ ___ _ __(_) __ _| |
\ \ /\ / / _ \ '_ \ | || | | | __/ _ \| '__| |/ _` | |
\ V V / __/ |_) | | || |_| | || (_) | | | | (_| | |
\_/\_/ \___|_.__/ |_| \__,_|\__\___/|_| |_|\__,_|_|
The tutorial to rule them all
Welcome! Let's get you started on your web journey. There are a few major components to understanding how the web works, so we will break it down into each of those components.
Unfortunately, this tends to take a little time, but getting a development environment setup put together is critical to having a good experience with programming. Technically, you can use Notepad to do all of your coding. In practice, there are tools that are much more powerful for doing this stuff.
Bash is a Terminal Shell language for most servers. Windows, unfortunately, does not have Bash support. For Windows, download git for windows. link.
Node.js is the primary server side language that we will be learning. Learn it, and learning other serverside languages will come easily, as the principles will transfer. For Windows, download node.js link.
A good text editor will do so much more than edit text. It will give you suggestions, find bugs, color code different structures, and more. This is your choice, and you will likely use several over the course of time.
- Atom by Github
- This is what I currently use. It allows users to create packages to extend the main code base, which means you get to pick and choose what you want it to look like. Atom is an electron app, meaning it is written in Javascript as well. This means if you ever want to dig in and customize it, you are completely able to.
- VSCode by Microsoft
- I've heard a lot of good things about this. It is also an electron app, so you will be able to customize it as needed. It also has a lot of package support.
- WebStorm by Jetbrains
- I'm pretty sure there is a community edition of this. JetBrains is nice if you plan on learning other languages, as each of their IDE's (Integrated Development Environments) are similar.
- Vim / Emacs
- Both of these are commandline text-editors. They are useful to learn for when you connect to external servers and can't use a normal IDE, but I don't recommend them for everyday development. Some people swear by vim, but they are the old guard... :)
Bash Script is one of the ways we can directly communicate with the computer. At first, the commands look weird, but you get used to them over time. Bash is extremely helpful when you connect to external servers, and it is the primary way we run code on our local computers.
Open your Bash shell (Mac / Linux, open Terminal, Windows, open Git For Windows).
Here are some basic commands for navigating your file system:
command | Result |
---|---|
ls | Lists files in current directory |
ls path | Lists files in path directory |
ls -a | Lists all hidden and non hidden files |
pwd | Print Working Directory |
cd path | change directory to path |
cd .. | Go to parent Directory |
mkdir name | Make directory named name in current directory |
rm path/to/file | Deletes file |
rm -rf path/to/folder | Deletes everything in folder |
Be warned with rm... it will assume you know what you are doing...
Next, it is helpful to know about what the .
means. After running ls -a
, you will see there is a .
..
and sometimes .<filename>
. .
in Bash means your current folder. ..
in Bash means the folder's parent directory. .<filename>
means it is a hidden file that you don't normally need to be aware of (or how hackers hide files from you... one of the two).
Usually, Bash can auto-fill directories. After typing the first few characters (i.e Des), push tab (i.e Desktop/). Try pushing tab twice. This frequently pulls up the files in that directory.
Now, with your bash knowledge, we can learn about version control.
Git is a software known as Version Control. It allows us to track changes and 'jump' forward and backward through those changes. Additionally, it allows multiple people to work on the same project at the same time while reducing conflicts between those people.
One thing to note is that git is not the same thing as GitHub. Git is software that allows you to create 'Repositories' (code bases) and track the changes in those code bases. GitHub is a place to store those repositories (alternatives exist like BitBucket and Gitlab).
Open your Bash Shell, cd into a new folder for web projects, and run the following:
git clone https://github.com/14gasher/webTutorial.git
You should see your terminal start flashing with messages until it says 'complete'. Now, run the following:
ls -a
You should see a new folder that contains all of the code in this repository. Open that folder with your text editor and take a look at it.
Git uses a 2 stage process to track changes:
git add <path/to/file/or/folder>
git commit -m 'Message about what changed'
So, we make changes to our program, we add those changes (called staging), then we commit them (make the changes official with a note of what we did).
Normally, the flow you will do is as follows:
git add .
git commit -m 'Message about what changed'
or, add everything in the project folder, commit it all, and say what you changed.
How do we look back in time to see how this repository has changed?
Run git log
. It will open a screen that shows you each commit within that repository. They look like the following:
commit 33ccdd6c2efd18553aceb68317b80ce05be071dd (HEAD -> master)
Author: 14gasher <[email protected]>
Date: Thu Feb 14 11:08:15 2019 -0700
Initialized
You'll note that every commit has an id (33ccdd6c2efd18553aceb68317b80ce05be071dd),
and some commits have additional 'pointers' to them like (HEAD -> master)
Type q
to exit that screen.
We can 'jump' back and forth in time by running the following:
git checkout <commitId>
This will change the folder to become exactly the same as it was back when it was committed at that point. Try running
git checkout 33ccdd6c2
and looking at the change in the folder... Nearly everything is gone! That is because you jumped to the very first commit in this repository. You'll note that you didn't need the entire id, only about the first 8 characters. Git is smart enough to figure out what you mean.
To get back to the latest code, run
git checkout master
You'll note that we didn't give it a commit id, but gave it master
. master
is a 'branch' within our code base, and is usually the main branch of code for all projects.
Branches allow us to separate development if we are working on something new. We don't want to start working on something, then throw it all away when a new feature takes priority. Rather, we create a branch for each new feature. We do so by running the following:
git checkout -b newFeatureBranchName
This creates a new branch which starts out wherever the current branch we were on was (If I ran it while on the master branch, it will start with the same code as master), and then moves to the new branch. If we make commits to that branch, those changes will stay on that branch.
Now, you can switch back and forth between branches by running that same command:
git checkout anotherFeatureBranch
Making changes on our local machine is great, but we want to share those changes. We do so by running the following:
git push origin myBranch
What this means is git will push the changes to the 'myBranch' branch of the code to the origin server.
Origin is setup to be the server where you first downloaded the code from. So, in our case, if you run the following:
git remote -v
you should get:
origin https://github.com/14gasher/webTutorial.git (fetch)
origin https://github.com/14gasher/webTutorial.git (push)
When working on a team, we will sometimes want to get the code that they pushed to the server. Run the following:
git pull origin myOtherBranch
to pull that branch from the server.
While it is possible to merge branches using Git, most teams use a process called pull requests to merge.
After pushing a branch up to the origin server, login to where the repository is held, and click on New Pull Request. Select the branch that you just pushed. This will alert all members of your team that you are ready for your changes to be merged in. Others will review your code, and approve, then merge your pull request in with the master
branch.
Alright! You survived the gross stuff. Onto the reasons you came here, web development. HTML is a variant of XML which means you will get used to this syntax quickly: <blah> ... </blah>
.
With your Text Editor, open up the minidemos/myFirstHtml.html file. Additionally, open the file with your web browser. You should notice that each of the elements already have some style defined to them. In the style tag near the top, try changing p color from gray to magenta. Refresh your webpage after saving the changes.
You'll notice that the inline styled p is still black, even though the others are not. Inline styling is one way of ensuring that an element has a particular style.
However, there is an even more powerful way: CSS. More on that later.
Now that we have seen some html, let's talk about terminology. An element can have parents and children. If something comes between the opening and closing element's tags, that thing is a child of that element, and likewise, that element is the parent of that child. This will become more important when we talk about Javascript on the Web.
Here is more in depth of the structure:
<parent attribute1='value1' class='class1 class2' id='id1'>
<child class='class3' id='id2'></child>
<child id='id3'></child>
<child class='class3'>
<grandchild></grandchild>
<!-- Comment comment comment -->
</child>
</parent>
Nodes (or elements), can typically have any number of children and grandchildren. They may have distinct attributes, and all can have the class and id attributes (but don't need to). Id's should be unique (go figure), while classes can be repeated. Finally, when you see <!-- Comment comment comment -->
, you know that there is something there as a note. Comments are ignored by the parser, so you can use them to get rid of blocks of code temporarily.
Convention holds that if something is a child of another element, indent it in. This allows us to quickly scan and see what is going on in the document. Your Text Editor should be able to do this automatically (and even auto indent an entire document if it looks off).
Raw html rarely looks pretty. CSS, or Cascading Style Sheets, is how we go about making them look good. CSS allows us to select elements, classes, ids, or combinations of the above and apply styles to each.
Open minidemos/myFirstHtml.html in both your browser and text editor.
Add the following as a new child to the <head>
tag:
<link rel="stylesheet" href="myFirstStylesheet.css" />
and delete the style tag. Save the page, then refresh your browser and observe the changes.
In your text editor, open minidemos/myFirstStylesheet.css and take a look.
Every p has been made gray, except for the ones with the class .myFirstClass which overrides the color to be purple. The id #myFirstId then overrides that, and finally, inline styling will override all of the above. Play around with the style sheet, and see what happens if you try to change the p color later in the sheet.
CSS is cascading because every new definition will override the one above it if it has been redefined. The more specific the target, the more it will override. For example, take a look at the following css:
/*Example 1*/
.change {
color: red;
}
div.change {
color: blue;
}
div#id.change {
color: purple;
}
/*Example 2*/
div#id.change.other {
color: red;
}
/*Example 3*/
div div.change p span {
color: magenta;
}
In example 1, anything with the class of 'change' would have the font render red, unless if the element was a div. If it is a div, then the font will be blue, unless the div had the id of 'id'. That div will have purple font.
In example 2, we are changing the div with id of 'id', and classes 'change' and 'other' to have red font.
In example 3, any span inside of a p in a div classed 'change' inside of a div will have a font color of magenta.
CSS can get complicated quickly if care isn't taken when using classes and id's. It may be easier to change example 3 to the following:
span#customSpan {
color: magenta;
}
and give the span an id, or to just use inline styling.
Sometimes with CSS, we are using the same color, font, or other value repeatedly. Rather than typing it repeatedly, then replacing each occurrence when that value needs to change, we can assign that value to a variable. Add the following to the top of your CSS file:
:root{
--firstColor: red;
--secondColor: blue;
}
Now, you can use the variable like this:
p {
color: var(--firstColor);
fill: var(--secondColor);
}
p.reverse {
color: var(--secondColor);
fill: var(--firstColor);
}
When those colors need to be changed to be something less ugly, you can change it once, and have it apply everywhere (a concept to remember...).
This is the more exciting part of websites... making them actually interactable. Javascript is an implementation of Ecmascript, which is why you'll hear about ESX a lot in web development. Not every browser fully implements the Ecmascript standard which makes for some difficult programming at times... (internet explorer). But, there are ways around that. Before we get into that, let's explore the language.
First things first, variables. A variable is something that holds a value. We can create variable in 3 ways in javascript:
const a = 1
let b = a + 1
var c = a + b
// This is a comment by the way...
/*
And
This
is
a
multiline
comment.
*/
const
means that the variable is constant, and cannot be reassigned. Always use this when possible as it makes the code easy to understand and prevents errors.
let
means that the variable may be reassigned. Use this when you can't use const
.
var
is like let
, but uses something called function scoping... Just never use it. Ever. Replace it with const
and let
.
Loops let us do things repeatedly in javascript.
while is the simplest loop. While the condition is true, repeat
let a = 1
while(a < 5) { // Condition is in the parenthesis
a = a * 2 // this looks weird, but we are reassigning a to be whatever a was times 2
}
/*
a: 1 < 5 === true, so repeat
a: 2 < 5 === true, so repeat
a: 4 < 5 === true, so repeat
a: 8 < 5 === false, so stop
*/
for is one of the most used loops. Usually if you want to do something a fixed number of times.
let a = 1
// Define variable; condition; how variable changes
for(let index = 0; index < 3; index += 1) {
a *= 2 // This is a shorthand of saying a = a * 2
}
/*
index: 0 < 3 === true, so a *=2 (now 2)
index: 1 < 3 === true, so a *=2 (now 4)
index: 2 < 3 === true, so a *=2 (now 8)
index: 3 < 3 === false, so end
a === 8
*/
Sometimes, we want to do different things based on what we received.
if / else if / else The most common way to move control
if(someCondition) {
// Do stuff
} else if (anotherCondition) {
// Do something else
} else {
// If all else fails, we do this
}
// Note that I can get rid of the else if and else, or add more else ifs when needed.
switch Perfect for when you expect certain values
switch(val) {
case 'steven': // if val is 'steven'
// do stuff
break
case 'george': // if val is 'george'
// do stuff
break
default: // if val is something else
// do stuff
}
Node.js is a server side language which uses Javascript as the primary language for the server. This makes web development fast as you only need a single language for the front and back parts of your web application.