This exercise will get you started learning the basics of JavaScript in the browser.
You will learn how to:
- Set up your development environment
- Create "Hello world"
- Make your code interact with the web page
- ✏️ Start by cloning this repository into a folder on your computer if you haven't done so already. If you've never used git before, you can alternatively use the the "Download ZIP" button on the repository home page. Click the green "Code" button and then "Download Zip"
- 📖 Although you have this
README.md
file on your computer, it's easier to read it on GitHub with formatting. We therefore recommend you keep a web browser tab open with the exercise tasks.
✏️ Open exercise1.html
both in Chrome and Visual Studio Code. Make sure changes to the HTML file are reflected in the browser.
✏️ To make our example web page run JavaScript we need to add a <script>
element.
✏️ Add the following <script>
element just before the closing </head>
element:
<script>
alert("Hello world!");
</script>
Refresh your page (hit F5
or CTRL+R
/ CMD+R
).
The result should be a box popping up saying 'Hello world!'. How exciting!
❗ Declaring scripts directly in HTML inside a
<script>
-tag is not good considered good practice, in later exercises we will be doing all coding inside external.js
files loaded into the page.
All browsers supply an API called the DOM (Document Object Model). The DOM API gives developers access to manipulate the web page markup dynamically via a tree structure called the DOM tree. Each HTML element in the web page is represented as a node in the tree.
This is what the DOM structure of exercise1.html
looks like, with the script
-tag now located in the <head>
-section (collapsed in image below).
We are going to use a DOM API method called querySelector
to replace some text in the web page, but we need to think about the order we do things.
✏️ Replace the contents of the <script>
element we created in the last example with the following code:
var paragraph = document.querySelector("p");
paragraph.innerHTML = "Hello Nerdschool";
Refresh the page (hit F5 or CTLR + R / CMD + R).
Apparently nothing happened so it's time to take on our detective hat 🕵️.
✏️ Open the Chrome or Firefox Devloper Tools by doing one of the following:
- Using Google Chrome: Select More Tools > Developer Tools from the Chrome Menu.
- Using Firefox: Select the hamburger menu at the top right corner of the browser, select
Web Developer
and clickToggle Tools
. - Firefox/Chrome: Right-click on a page element and select Inspect
- Firefox/Chrome: Use the keyboard shortcuts
Ctrl+Shift+I
(Windows) orCmd+Opt+I
(Mac)
✏️ Go to the Console panel. (Don't worry about all the other buttons and panels, we will revisit DevTools in the next exercise.). Refresh the page again.
exercise1.html:13 Uncaught TypeError: Cannot set property 'innerHTML' of null
Looks like we're trying to set innerHTML
on something that's null
. It's not to hard to take a guess based on our code what the null
thing is, but let's explore another debug tool while we're at it.
✏️ Between the two existing lines, add the following:
console.log("The current paragraph is:", paragraph);
Refresh the page with the Console panel in DevTools still open.
The current paragraph is: null
Well we already knew that, but becoming comfortable with console.log()
is crucial. This is one of your primary tools of inspecting what's going on at runtime.
Ok so back to our problem of a null paragraph. Can you guess why this is happening?
No really, think about it for a few seconds.
The DOM is read sequentially from top to bottom. As the code is now, our <script></script>
block is executed before anything in the <body>
is even read initially. So when we try to find a <p>
element, none exists because the parser haven't found it yet.
✏️ Make sure your <script>
element is located below the <p>
(paragraph) element. (Hint: the <script>
block can live inside of the <body>
).
Refresh your page. The result should be the text 'Hello Nerdschool' displaying in the paragraph below the heading.
✏️ Try replacing the text with something else, then refreshing the page.
In the first line we query the DOM via the document
object, passing in a selector to find the first <p>
element in the web page. We then change the contents of the element by setting the innerHTML
property.