Views
We're going to create a personal website with the following pages:
Home
About
Blog
Objectives:
Practice stubbing out routes
Learn how to set up views
Prerequisites:
Know how to write a GET route in Node/Express
Part 1: Routes
We're going to stub out the routes for the home, about, and blog pages!
1. Set up your app Create a new Node/Express project.
2. Create the following routes:
Make sure the message displays on the page when you navigate to the appropriate URL.
Route
HTTP Verb
URL Pattern
Message
Home
GET
/
"This is the Home Page!"
About
GET
/about
"Some stuff about me will go here."
Blog
GET
/blog
"A directory of all my blog posts will go here."
Part 2: Views
Writing text to a web page using res.send()
gives us something to look at, but isn't very pretty. Instead of sending plain text, let's start serving HTML files. Since each page will display different HTML, we'll have several HTML files, or views.
1. Create a views folder inside your project directory. Inside this folder, create three HTML files:
index.html (this is the standard filename for the view associated with the base URL)
about.html
blog-directory.html
2. Put some basic HTML in these files so you can test them.
3. In your routes, replace the res.send(<message>)
with res.sendFile(<absolute file path>)
(docs)
res.sendFile()
takes an absolute path, so we can't just give it ./views/index.html
. How do you get the absolute file path for each of these files? Don't know/don't care? You're in luck! __dirname
is a Node keyword that gives us the absolute path of the current directory (docs), so we can just tack that on in front of the relative path
Your home route should look like this:
Test it out to see if your HTML shows up!
Make sure to do this for all three routes. Now check to see that your html is coming through on the browser.
Last updated