Update / Delete
We aren't adding any new concepts when we add the rest of CRUD / rest of the HTTP verbs, but the process of each verb has many steps that must be completed by the server and client.
Updating
- (Assume user has already created something that is stored as data )
- User requests the form to edit that thing 
- Using RESTful style routes that would be - /pokemon/1/edit
- That requested form already has each piece of data for that record pre-filled in the form: 
'<form method="POST" action="/pokemon/'+pokemon.id+'?_method=put">'+
  '<div class="pokemon-attribute">'+
    'id: <input name="id" type="text" value="'+pokemon.id+'"/>'+
    'name: <input name="name" type="text" value="'+pokemon.name+'"/>'+
  '</div>'+
'</form>';
app.put("/pokemon/:id", (request, response) => {
  //read the file in and write out to it
});
Deleting
- (Assume user has already created something that is stored as data )
- User requests or already has the form to delete that thing
'<form method="POST" action="/pokemon/'+pokemon.id+'?_method=delete">'+
    '<input name="id" type="hidden" value="'+pokemon.id+'"/>'+
    '<input type="submit" value="delete this"/>'+
'</form>';
app.delete("/pokemon/:id", (request, response) => {
  //read the file in and write out to it
});
MethodOverride
HTML <form>s do no yet support PUT and DELETE requests, so we need a way to circumvent the problem.
The method-override npm library is designed to get over this limitation.
You will need to install the method-override package using npm install method-override and make sure Express uses it.
index.js
// Set up method-override for PUT and DELETE forms
const methodOverride = require('method-override')
app.use(methodOverride('_method'));
Then, in your HTML page, you will have to specify _method=<VERB>, where VERB can be either PUT or DELETE. Here is an example of PUT.
edit
'<form method="POST" action="/'+pokemon.id+'?_method=put">'+
  '<div class="pokemon-attribute">'+
    'id: <input name="id" type="text" value="'+pokemon.id+'"/>'+
  '</div>'+
'</form>';
For more examples and details, as usual, read the method-override documentation.
Pairing Exercise
Run the following code:
Create and respond to a PUT request:
mkdir updat
cd updat
npm init
npm install express
npm install method-override
touch index.js
Add the method override config code:
(it goes after you declare the app variable)
// Set up method-override for PUT and DELETE forms
const methodOverride = require('method-override')
app.use(methodOverride('_method'));
Add the get route form that creates the request:
app.get('/editsomething',(request, response) => {
  let html = '<form method="POST" action="/putrequest?_method=put">'+
      '<input name="id" type="hidden" value="something"/>'+
      '<input type="submit" value="delete this"/>'+
  '</form>';
  response.send(html);
});
Add the put method route to your app:
app.put("/putrequest", (request, response) => {
  console.log(request.body);
  //read the file in and write out to it
  response.send('yes');
});
PUT with CURL
Use a CURL command to make a POST request to your server. (remember PUT is interpreted in express!)
(We can use CURL to create the request, without having to construct anything else)
curl -d "monkey=banana&koala=eucalyptus" -X POST http://localhost:3000/putrequest?_method=put
Further
Add in some pretend data to edit:
- install and use jsonfilenpm library
- put some fake data in your data.json:{"name":"susan chan"}
- render this data in your form
- use a put request to change the data stored in the json file
Further
Make your pretend data more complicated:
{
  "names" : [
    "susan",
    "gabriel",
    "chee kean"
  ]
}
- Create a get route for each thing in the list: /names/0will render a page withsusan
- Add a link to this page to an edit form page: <a href="/names/0/edit">edit</a>
- This page should render a form with the name prepopulated in the form input
- Change the action of the form to be specific to this particular name: <form action="/names/0" ....
- Change the put request route to handle the editing of a particular element of the names array.
Further
Change the names array to contain an array of objects, instead of an array of strings.
{
  "names" : [
    {
      "name" : "susan",
      "height" : "12"
    },
    ...
  ]
}