title |
before |
notes |
Sign in to GitHub |
**We’ll be using GitHub as our code version control system—and our web host.**
We’ll put all of our coding exercises on GitHub where they will be live websites visible to anybody.
|
label |
text |
Reminder |
For most coding exercises you won’t need to perform these steps, you’ll be using [Markbot](/courses/web-dev-1/using-markbot/) to hand in all your work. |
|
|
|
title |
before |
notes |
Create a new repo |
Before starting this project we need to create a repository on GitHub. The repository will hold all of our website code, all the history of our project, and be our host.
data:image/s3,"s3://crabby-images/fb0d9/fb0d911ba496bb2d1eca6c3b29e6442da8d1f78d" alt=""
When we get to the new repository page there’s a few fields to complete.
data:image/s3,"s3://crabby-images/03115/03115e9d13b1184ea2810b00e47aa52e5f8774e8" alt=""
- **Repository name** — create a unique name for the repo, make sure it follows the [naming conventions](/topics/naming-paths-cheat-sheet/#naming-conventions).
- **Description** — come up with a short description describing the purpose of the project.
- **Public/Private** — choose “Public” because we don’t have a paid accounts.
- **Initialize this repository with a README** — always make sure this is enabled.
|
label |
text |
Naming conventions |
Don’t forget to follow the [naming conventions](/topics/naming-paths-cheat-sheet/#naming-conventions). |
|
|
|
title |
before |
image_steps |
Set up for hosting |
Before we write any code we’re going to set up the code repository so it’s a live, hosted website.
By default the code stored on GitHub isn’t assumed to be a website—any code can be store on the service. We need to opt-into the free website hosting that GitHub provides, named GitHub Pages.
|
url |
text |
settings.jpg |
Click the “Settings” tab at the top of the repository.
|
|
url |
text |
gh-pages.jpg |
Scroll down a little and under the “GitHub Pages” section, where it says “None”, select “master branch”. **The change will automatically save.**
|
|
|
|
title |
before |
Clone to computer |
After our repository is created and set up we need to clone (copy) it to our computer by pressing the “Clone to desktop” button.
data:image/s3,"s3://crabby-images/76867/768678ac3044253b7a4211a2e5eb5588c4898d66" alt=""
The GitHub Desktop application will pop up and ask you where to save the repository. Put it into your `web-dev` folder—**you don’t have to make a folder specifically for this repo, the app will make it for you.**
data:image/s3,"s3://crabby-images/ef80a/ef80a8a9194a8bd1ae86547eeb3aa86adbc68bd8" alt=""
Then click the “Clone” button:
data:image/s3,"s3://crabby-images/40204/402047654e6cd1584cca8443d32c3f5c5da8ebcd" alt=""
|
|
title |
before |
Open in code editor |
We can now open up the project in our code editor.
data:image/s3,"s3://crabby-images/bad68/bad682e3d0fb610e9a0b3613e3d5257e1d3bbd0a" alt=""
Drag **the folder** that was created to your code editor in the Dock.
data:image/s3,"s3://crabby-images/7dbcd/7dbcd5f500ac16e8c6ecbb2b2b4fe1dfae354460" alt=""
|
|
title |
before |
folders |
after |
notes |
Add an HTML file |
We’re ready to make a new HTML file.
Go to `File > New` or press `⌘N` to make a new file.
|
label |
type |
first-website |
folder |
|
label |
indent |
index.html |
1 |
|
|
**Immediately save the file.** Call it exactly `index.html`. Put it into the `first-website` folder.
data:image/s3,"s3://crabby-images/1b70a/1b70a6e01618ee8234fc882e092f9d0d168e7925" alt=""
|
label |
text |
Naming conventions |
Don’t forget to follow the [naming conventions](/topics/naming-paths-cheat-sheet/#naming-conventions). |
|
label |
text |
Shortcut |
Use `⌘S` to save. |
|
label |
text |
Shortcut |
Use `⌘⌥N` to make, name, and save a new file in one step. Only works when a folder is open in your code editor. |
|
|
|
title |
before |
code_lang |
code_file |
code |
after |
Write some code |
In the `index.html` file write a little bit of HTML:
|
html |
index.html |
<h1>It works!</h1>
|
data:image/s3,"s3://crabby-images/a89ba/a89ba5aa903f2644ca16f2be16d6852d47b6be78" alt=""
**Then save!**
|
|
title |
before |
notes |
Test the website |
After saving our HTML we need to test it in a web browser to confirm it works.
**Use Chrome or Firefox to test websites while developing—Safari isn’t good enough.**
Double click on the icon in Finder to open it in the browser.
data:image/s3,"s3://crabby-images/c10fa/c10fab6e1adcf30975119f022b3710fe251f749e" alt=""
Make sure it looks all good in the browser.
data:image/s3,"s3://crabby-images/cc1ed/cc1edb8c9adb21e33773357f8ab733dad4fef64c" alt=""
*Leave this tab open all the time while working to easily jump back and forth.*
|
label |
text |
Reminder |
Leave this tab open while working and jump back to the window with `⌘Tab` when you want to test—press `⌘R` to refresh the browser. |
|
label |
text |
Shortcut |
`⌘S`, `⌘Tab`, `⌘R`, `⌘Tab`, repeat. |
|
|
|
title |
before |
notes |
Commit & sync |
When happy with how it looks in the browser it’s time to make a commit to save the state of our code.
**Make sure to write a descriptive message!**
data:image/s3,"s3://crabby-images/40b31/40b3191ef34246af92629556b893421fc62b3f74" alt=""
Then send it to the GitHub website with the “Push” button.
data:image/s3,"s3://crabby-images/bb619/bb6196f740e2c780a1bfb06d075ce5aa5386b31e" alt=""
|
label |
text |
Shortcut |
`⌘Return` to save the commit. |
|
label |
text |
Shortcut |
`⌘P` to push your changes. |
|
label |
text |
Best practices |
Refer to the [**commit messages cheat sheet**](/topics/commit-message-cheat-sheet/) for the commit best practices.
|
|
|
|
title |
before |
code |
after |
Test the live website |
After syncing our website will be live, online, at a specific URL.
The URLs always look like this:
|
|
Find the URL on the GitHub website under the repository’s “Settings” tab.
data:image/s3,"s3://crabby-images/5520e/5520e371d79f68d5daa543eeebb51f1b93c9d63c" alt=""
**And you should see your website!** The URL is completely open to anyone in the world.
data:image/s3,"s3://crabby-images/b6cee/b6ceecc25c2d353ed8b7cd60713390defafd66b1" alt=""
|
|
title |
before |
Fork instead… |
**For all the code exercises in class we don’t have to go through the process of setting up for hosting—the assignments are all ready.**
**We’ll be using the [fork & pass tests method with Markbot](/courses/web-dev-1/using-markbot/) to hand in all work.**
[**That lesson comes next ➔**](/courses/web-dev-1/using-markbot/)
|
|