TYPESCRIPT

¿En Node?

Laura Ciro

@ltciro

 

Co-organizadora en @pionerasdev

Desarrollo en Ruby, Node, Arduino para IoT

Code legacy

El tiempo es lo más valioso que puedes gastar.

chequeo de tipos

Tipado Estático

 

let nodeIs: string = "Genial" //string

nodeIs = true // error

 

Tipado Dinámico

 

let nodeIs = "Genial" //string

nodeIs = true // boolean

 

JS chequeo dinámico 

 

 

 

 

2 == "2" // true

 

[] == 0 // true

 

false == [] // true

 

 

¿coerción? 

===

 

 

funciones usadas  sin ser declaradas 

 

 

TypeScript  chequeo estático

 

 

const num1 : number = 2;

const numA : string = "2";

 

num1 + numA // genera error

 

 

El chequeo estático logra evitar un 15% de errores en producción  

 

 

To Type or Not to Type: Quantifying Detectable Bugs in JavaScript

TypeScript empieza y termina en Javascript

alternativas TypeScript

Por qué TypeScript

 

  • Herramientas.
    
  • Últimas funcionalidades de ES.
  • Interoperabilidad (@typos -  js ).
  • Código mas legible.

 

Documentación

 

import { Request, Response } from  "express";

interface SuperHeroRequest extends Request {
superheroName: string;
}

//And then use it in a route:

app.router.get("/heroes", (req: SuperHeroRequest, res: Response) => {
 if (req.superheroName) {
   res.send("I'm Batman")
 }
});

Por ultimo, la comunidad

Instalación

 

npm install --save-dev typescript
npm install --save-dev @types/node

 

 

 

 

 

tsconfig.json

 

 

 

 

 

 

{
  "compilerOptions": {
    "allowJs": true,
    "target": "es2017",
    "module": "commonjs",
    "outDir": "dist"
  },
  "include": [
    "main/**/*.ts"
  ],
  "exclude": [
    "node_modules"
  ],
  "typeRoots": [
    "./node_modules/@types"
  ]
}

Package.json

 

 

 

 

$ npm run prod

 

 "scripts": {
    "compile": "node_modules/.bin/tsc",
    "prod": "npm run compile && node ./dist/main.js"
  },

Dev

Instalación

 

npm install --save-dev ts-node
npm install --save-dev nodemon
npm install --save-dev cpy-cli

 

 

 

 

 

 

package.json

 

 

 

 

 

$ npm run prod

o

$ npm start
"scripts": {
    "compile": "node_modules/.bin/tsc",
    "copyfiles": "cpy '**/*.json' '../dist/' --cwd=main --parents",
    "prod": "npm run compile && npm run copyfiles && node ./dist/main.js",
    "start": "npm run build:live",
    "test": "mocha -r ts-node/register test/*.ts test/**/*.ts test/**/**/*.ts 
             test/**/**/**/*.ts|| true",
    "build:live": "nodemon --exec ts-node -- ./main/main.ts"
  }

NEST

Una solución al problema de arquitectura en Node

Está construido con TypeScript

combina los mejores conceptos de:

 

OOP (programación orientada a objetos)
FP (Programación Funcional)
FRP (Programación Reactiva Funcional)

¿Por qué nestjs ?

 

  • Arquitectura

  • Fomenta en los devs aprender conceptos

  • Guía y estándar para devs juniors/mid o de diferente background

  • Agnóstica-plataforma

  • Integración con muchas librerías

  • El uso de TypeScript  y rxjs

 

@decorators

Nest.js utiliza los decoradores  entre otras cosas para definir y reconocer elementos dentro de nuestra aplicación

@controller

@controller

@modules

@injectables

providers

middlewares

pipes

guards

interceptors

Entry

CLI (v.5)

$ npm i -g @nestjs/cli

$ nest new project-name

Puedes usar:

$ nest generate <schematic> name

$nest info

    Docs

    Ejemplos

     

     

    ¡ Gracias !

    ¿Preguntas?

    TypeScript & NestJS

    By Laura Ciro

    TypeScript & NestJS

    • 1,342