Welcome to your first Node app!!
This is where things start to get a little more complicated, but a heck of a lot more fun!
- Install the EJS language support extension for VS Code.
- Open a terminal window and type
yarn install
- Start up the server by typing
yarn dev
Your node application is now running at https://localhost:8000
We will no longer be using the "Live Server" extension in VS Code.
When we type yarn dev
in the terminal, it will spin up a node
environment that will render our server-side app to the browser.
If you find yourself unable to stop trying to run files with it, you could uninstall the extension. We will not need it for the rest of the bootcamp.
If you look in the package.json
file you will see all of the external dependencies, or modules, that we will need for today's workshop.
package | Description |
---|---|
express | Fast, unopinionated, minimalist web framework for node. |
nodemon | nodemon is a tool that helps develop node.js based applications by automatically restarting the node application when file changes in the directory are detected. |
morgan | HTTP request logger middleware for node.js |
ejs | Embedded JavaScript templates. |
moment | A lightweight JavaScript date library for parsing, validating, manipulating, and formatting dates. |
├── __solution
├── __workshop
| ├── exercisesP1.js
| └── ...
├── data (data files used to complete exercises)
| ├── dataFiles.js
| └── dataFiles2.js
├── node_modules (where all external dependencies are saved)
| ├── ...
| └── ...
├── public (folder that serves static files)
| ├── styles.css
| └── static.html
├── views (location of all the ejs template files)
│ ├── pages
│ │ ├── homepage.ejs
│ │ └── exercises
| | ├── q1.ejs
| | └── ...
│ └── partials
│ ├── head.ejs
│ ├── header.ejs
│ └── ...
├── .gitignore
├── package.json (where we keep a record app setup)
├── README.md (this file)
├── server.js
└── yarn.lock ("locks" the dependency versions)
<%
'Scriptlet' tag, for control-flow, no output<%=
Outputs the value into the template (HTML escaped)<%-
Outputs the unescaped value into the template<%#
Comment tag, no execution, no output%>
Plain ending tag
- When you run
yarn install
, yarn reads thepackage.json
and downloads the dependencies in thenode_modules
folder. It will also generate ayarn.lock
file if it doesn't already exist; if it does exist, it will defer to the version numbers in that file, rather than taking the most recent version available remotely. This is to ensure compatibility and prevent breaking changes in dependencies from, well, breaking our app. ejs
files are basically superchargedhtml
files. We can pass in JavaScript values. It allows us to do TONS of cool stuff. 😀- Use the
styles.css
to add some zing to your exercises