The goal of this exercise is to create a basic Node.js project, set it up using npm, incorporate external packages, and use require
to import and use an external package. Additionally, you will learn to set up and run the project using npm scripts and debug using Visual Studio Code.
-
Initialize the project:
- Create a new folder for the project and open it in VS Code.
- Open the terminal in VS Code and run the following command to initialize the project:
npm init
-
Install an external package:
- Use npm to install the
colors
package (used for styling terminal output):npm install colors
- Use npm to install the
-
Create the main file:
- In the root folder, create a file named
index.js
. - Add the following code to
index.js
:const colors = require('colors'); const name = 'Student'; console.log(colors.blue(`Hello, ${name}! Welcome to the Node.js exercise.`)); console.log(colors.green('This message is styled using the colors package!'));
- In the root folder, create a file named
-
Set up an npm script:
- In your
package.json
, add the following start script under thescripts
section:"scripts": { "start": "node index.js" }
- In your
-
Debug using VS Code:
- Open VS Code and set a breakpoint on the line where the
colors.blue
function is called. - In VS Code, press
Ctrl+Shift+D
to open the debug view. - Create a
.vscode/launch.json
file by clicking "create a launch.json file" and configure it for Node.js debugging:{ "version": "0.2.0", "configurations": [ { "type": "node", "request": "launch", "name": "Launch Program", "program": "${workspaceFolder}/index.js" } ] }
- Run the debugger from VS Code.
- Open VS Code and set a breakpoint on the line where the
-
Run the project:
- To run the project, use the following command in the terminal:
npm start
- To run the project, use the following command in the terminal:
By completing this exercise, you will learn how to:
- Initialize a Node.js project using npm.
- Install and use external packages.
- Set up npm scripts.
- Debug a Node.js application in VS Code.
In this exercise, you will practice:
- Interfaces
- Union Types
- Functional programming
- Typescript project structure
Implement a shape calculation and reporting system. The app will calculate the area and circumference of different shapes, including circles, rectangles, and triangles. You will then generate a shape report based on the calculated values.
-
Set up the project structure with the following files:
shapes.ts
: Define the interfaces for specific shapes and export theShape
type and theShapeKind
type.calculations.ts
: Implement the shape calculation functions and export theShapeCalculator
type,calculateArea
function, andcalculateCircumference
function.report.ts
: Create thecreateShapeReport
function that generates a shape report and export it.index.ts
: Use the implemented functions to calculate the area and circumference of shapes and generate the shape report.
-
Implement the
shapes.ts
file:- Define the interfaces
Circle
,Rectangle
, andTriangle
for each specific shape. Each shape interface should have akind
property of a discriminated union type. Export these interfaces. - Define the
Shape
type as a union type ofCircle
,Rectangle
, andTriangle
. - Define the
ShapeKind
type as the mapped type that extracts thekind
property values from theShape
type.
- Define the interfaces
-
Implement the
calculations.ts
file:- Import the
Shape
type fromshapes.ts
. - Define the
ShapeCalculator
type as a function type that accepts a shape of typeShape
and returns a number. - Implement the
calculateArea
function that calculates the area based on the shape type using a switch statement. Export this function. - Implement the
calculateCircumference
function that calculates the circumference based on the shape type using a switch statement. Export this function.
- Import the
-
Implement the
report.ts
file:- Import the
Shape
andShapeKind
types fromshapes.ts
, and theShapeCalculator
type fromcalculations.ts
. - Implement the
createShapeReport
function that takes an array of shapes and a shape calculator function. Iterate through the shapes using afor...of
loop and generate an array of shape reports. Each shape report should have akind
property of typeShapeKind
and avalue
property of typestring
, which represents the calculated value. Export this function.
- Import the
-
Implement the
index.ts
file:- Import the necessary types and functions from
shapes.ts
,calculations.ts
, andreport.ts
. - Create instances of different shapes (e.g., circle, rectangle, triangle).
- Create an array of shapes containing the instances created in the previous step.
- Use the
createShapeReport
function withcalculateArea
to generate a shape report for the areas of the shapes. Iterate through the resulting array using afor...of
loop and log each shape's kind and calculated area to the console. - Use the
createShapeReport
function withcalculateCircumference
to generate a shape report for the circumferences of the shapes. Iterate through the resulting array using afor...of
loop and log each shape's kind and calculated circumference
- Import the necessary types and functions from