Visit the project website here
Read this entire page before you start
- Fork and then Clone this repo.
- The app should have one model with at least two properties.
- It should have all the CRUD functionality.
- It should contain all seven RESTful routes.
- This app will be very similiar to the fruits app, but the model must be different.
- DO NOT COPY AND PASTE ANY CODE FROM YOUR FRUITS APP OR ANYWHERE ELSE. It's okay to use it as a reference, but type it out. DO NOT COPY AND PASTE.
- Do one small step at a time, and then make sure that one step works, and commit before moving on. You are required to have at least 15 commits.
Remember: Use this list of RESTful routes as your guide for HTTP methods, CRUD functionalities, and URL formatting:
-
Don't forget to
npm init
in order to start your node project. -
If you get an error message that says module not found—did you install the module?
-
READ YOUR ERROR MESSAGES, first try to solve them by going through the error message. Then look it up (try googling the error message and including "express" and/or "mongoose"). Then compare to code that you know works, like the fruits app from class repo. Then slack an instructor.
-
Set up your db first and make sure it's connected.
-
Do one functionality at a time, and do each piece of that functionality one step a time. For example, maybe start with a user story like: "User should be able to add an item". Think: In terms of REST, that means you need "create" and "new." Don't do anything else until the user can add an item. Perhaps you'd follow steps like this:
- First make a "new" route that works at all and
res.send()
s some text back. Test it. - Then, make it render a template with a form. Test it.
- Then, make a "create" route for the form to
POST
to, and make sure submitting the form successfully hits the create route. Don't worry about the data or the database, justres.send()
some text back "hitting create route". Test it. - Then see if you can
console.log()
the submitted data ("req.body
"). And Test It. - Then see if you can get the post route to actually add the submitted data to the DB. Test it using the
mongo
CLI and by logging thecreatedItem
in your callback - Then worry about what should happen after the data is added. Maybe you should have an index page where the user can see the items?
- First make a "new" route that works at all and
-
Ok. so then you're gonna need to build an index route... and just focus on that until its done. And work in small steps... so maybe:
- First make a route that works at all and
res.send()
s some text back. Test it. - Then make a template that will be the index page. Just get the template rendering. Test it.
- Then make the index route actually get data from the db successfully, and test it with console.log().
- Then render the data into the template... etc..
- First make a route that works at all and
-
....And so forth. Make sure you're building your apps in this way. Take careful small well-reasoned steps, and do what you can to stay clear on what the goal of each step is. It is critical that you build these apps one step at a time, thinking about what functionality you need to add, and adding it one step at a time, thinking about what you're doing at each step and why. Do not just write out all your routes and try to fill them in without testing them.
-
console.log()
everything you can think of. -
Remember when you are submitting a form, you are making a request from the client, and your server has to respond to that request.
-
res.render()
is for rendering templates (ejs),res.send()
is for sending text,res.redirect()
is for sending a message to the browser that it should redirect to a new location. Remember, theres
object is how you 'respond' to the client. -
Use lesson notes and labs from this week as a guide only if you are completely lost. But make sure you are giving it a true effort and not taking the easy way out. No Pain, No Gain!
Add bootstrap to your project and use some of the basic styling for layout.
At a basic level, most layout challenges can be solved with the info on this page and this page.
Also in the docs, check out the Components section and some of the subsection. There's a nice collection of other styles you can use to easily get great professional default styling for things like forms or buttons
Tired of putting an entire html <head>
in every template? You should be. It's not very DRY or easily updatable. It'd be cool if we could just have one header.ejs
that has maybe our <head>
(or even more) and just include that in each template. Then we have way less repeated code, and if we ever need to make a sitewide change to the head, we could change it in one file instead of every template.
Here's some relevant pieces the EJS "documentation" (look at the "Includes" section), which includes information on how to do this:
Or here's a blog post about it and another blog post about it, and there are dozens more.
The EJS system of includes is beautifully simple; you just include
any template in any other template you need it in. Just be sure not to include 2 things in each other!