When you are creating express backend, you have two options: to use CommonJS or to use ECMAScript.
CommonJS is default for Node.
You can specify which one to use in package.json.
When you want to use CommonJS, you specify "type" : "commonjs". This is added in package.json by default when a new node project is created by using "npm init" command.
When you want to use ECMAScript, you have to change this type to module: "type" : "module".
The main difference between ECMAScript and CommonJS is in importing modules: ECMAScript uses "import" statement, while CommonJS uses "require" statement.
The below project create two different Hello, World projects in Express, one with CommonJS and other with ECMAScript.
======================================================================================
STEP 001 : Creating a new express project with commonjs with API code in separate file
======================================================================================
1. Create a React-Node Ubuntu container, with mounted volume.
2. Create a folder commonjs and change directory to that folder:
cd commonjs
3. Run the below command to create a new node project:
npm init
Keep on pressing <Enter> keys on all questions, we are going to use default names and settings only.
Next, install express:
npm install express
4. Inspect package.json by using command "cat package.json". You will find the below line by default:
"type" : "commonjs"
Thus, this project will use commonjs ("require" syntax).
5. Create a index.js file: (because the package.json by default contains the entry "main" : "index.js")
touch index.js
Open this file for editing:
vi index.js
Add the following code to this file:
-----------------------------------------------------------------------
index.js
-----------------------------------------------------------------------
const express = require("express");
const hello001 = require("./hello001.js");
const hello002 = require("./hello002.js");
const app = express();
//both index.js and hello001.js, hello002.js should be in same directory
app.use('/hello001', hello001);
app.use('/hello002', hello002);
app.listen(4000);
-----------------------------------------------------------------------
6. Create an hello001.js file in the same folder with below code:
-----------------------------------------------------------------------
hello001.js
-----------------------------------------------------------------------
const express = require("express");
const router = express.Router();
router.get('/', function(req, res){
res.send('GET route on HELLO 001');
});
router.post('/', function(req, res){
res.send('POST route on HELLO 001.');
});
//export this router to use in our index.js
module.exports = router; //this is required for commonjs
//export default router; //this is required for ECMAScript
-----------------------------------------------------------------------
7. Create an hello002.js file in the same folder with below code:
-----------------------------------------------------------------------
hello002.js
-----------------------------------------------------------------------
const express = require("express");
const router = express.Router();
router.get('/', function(req, res){
res.send('GET route on HELLO 002');
});
router.post('/', function(req, res){
res.send('POST route on HELLO 002.');
});
//export this router to use in our index.js
module.exports = router; //this is required for commonjs
//export default router; //this is required for ECMAScript
-----------------------------------------------------------------------
8. Run the project.
node index.js
The project will start running, but there will be no message displayed since we have not given one.
9. You can check the GET methods on the host computer's browser, browse to (THIS ASSUMES CONTAINER's 4000 port is mapped to 11000 port of host computer)
http://localhost:11000/hello001
and
http://localhost:11000/hello002
You should see the messages: "GET route on HELLO 001" and "GET route on HELLO 002" respectively on the browser.
10. You can check the POST method calls using POSTMAN.
In POSTMAN, use the same URLs as above and simply change API type to POST and send the request. (WE are not using any auth and also there are no request parameters/body required).
You should see the messages: "POST route on HELLO 001" and "POST route on HELLO 002" respectively on the browser.
11. Please find below the package.json for ready reference:
-----------------------------------------------------------------------
package.json
-----------------------------------------------------------------------
{
"name": "commonjs",
"version": "1.0.0",
"description": "",
"license": "ISC",
"author": "",
"type": "commonjs",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"dependencies": {
"express": "^4.21.2"
}
}
-----------------------------------------------------------------------
======================================================================================
========================================================================================
STEP 002 : Creating a new express project with ECMASCript with API code in separate file
========================================================================================
1. Create a React-Node Ubuntu container, with mounted volume.
2. Create a folder ecmascript and change directory to that folder:
cd ecmascript
3. Run the below command to create a new node project:
npm init
Keep on pressing <Enter> keys on all questions, we are going to use default names and settings only.
==> THE LAST QUESTION ASKED IS "type", for which the default answer is "(commonjs)".
You can type "module" here (without double quotes!, it will add double quotes by itself).
If you missed this, DO NOT WORRY, YOU CAN CHANGE IT IN STEP 4 below.
Next, install express:
npm install express
4. Inspect package.json by using command "cat package.json".
If you have already specified "type" as "module" in step 3 above, then you are good to go.
If you missed it in step 3 above, you can now edit package.json and change the type to module.
Open package.json in vi editior, if you find the below line:
"type" : "commonjs"
change it to:
"type" : "module" [DIFFERENCE 001]
5. Create a index.js file: (because the package.json by default contains the entry "main" : "index.js")
touch index.js
Open this file for editing:
vi index.js
Add the following code to this file:
-----------------------------------------------------------------------
index.js
-----------------------------------------------------------------------
import express from "express"; //[DIFFERENCE 002]
import hello001 from "./hello001.js"; //[DIFFERENCE 003]
import hello002 from "./hello002.js"; //[DIFFERENCE 004]
const app = express();
//both index.js and hello001.js, hello002.js should be in same directory
app.use('/hello001', hello001);
app.use('/hello002', hello002);
app.listen(4000);
-----------------------------------------------------------------------
6. Create an hello001.js file in the same folder with below code:
-----------------------------------------------------------------------
hello001.js
-----------------------------------------------------------------------
import express from "express"; //[DIFFERENCE 005]
const router = express.Router();
router.get('/', function(req, res){
res.send('GET route on HELLO 001');
});
router.post('/', function(req, res){
res.send('POST route on HELLO 001.');
});
//export this router to use in our index.js
//module.exports = router; //this is required for commonjs
export default router; //this is required for ECMAScript //[DIFFERENCE 006]
-----------------------------------------------------------------------
7. Create an hello002.js file in the same folder with below code:
-----------------------------------------------------------------------
hello002.js
-----------------------------------------------------------------------
import express from "express"; //[DIFFERENCE 007]
const router = express.Router();
router.get('/', function(req, res){
res.send('GET route on HELLO 002');
});
router.post('/', function(req, res){
res.send('POST route on HELLO 002.');
});
//export this router to use in our index.js
//module.exports = router; //this is required for commonjs
export default router; //this is required for ECMAScript //[DIFFERENCE 008]
-----------------------------------------------------------------------
8. Run the project.
node index.js
The project will start running, but there will be no message displayed since we have not given one.
9. You can check the GET methods on the host computer's browser, browse to (THIS ASSUMES CONTAINER's 4000 port is mapped to 11000 port of host computer)
http://localhost:11000/hello001
and
http://localhost:11000/hello002
You should see the messages: "GET route on HELLO 001" and "GET route on HELLO 002" respectively on the browser.
10. You can check the POST method calls using POSTMAN.
In POSTMAN, use the same URLs as above and simply change API type to POST and send the request. (WE are not using any auth and also there are no request parameters/body required).
You should see the messages: "POST route on HELLO 001" and "POST route on HELLO 002" respectively on the browser.
11. Below is the package.json for ready reference:
-----------------------------------------------------------------------
package.json
-----------------------------------------------------------------------
{
"name": "ecmascript",
"version": "1.0.0",
"description": "",
"license": "ISC",
"author": "",
"type": "module",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"dependencies": {
"express": "^4.21.2"
}
}
-----------------------------------------------------------------------
The only change you will notice will be in the "type" line.
========================================================================================