Skip to content

Latest commit

 

History

History
60 lines (42 loc) · 4.71 KB

README.md

File metadata and controls

60 lines (42 loc) · 4.71 KB

TypeScript - Notes

TypeScript notes Maintainer repo which will include basics to advanced concepts of typeScript along with some real world problems based on them.

What is Typescript

  • Typescript is a Javascript superset , what it means is a langauge which is built up on Javascript. It adds new feature to Javascript and provides advantages to it.
  • Typescript cannot be excuted by browser, since they browers have a javascript environment. Node.js also can't execute typescript.
  • Typescript is a powerful compiler to complile typescript code to javscript code. It provides a cleaner syntax to javacript code.
  • Typescript adds types in javascript. Which helps in identiying errors before runtime . Provides error checking mechanism.

Install Typescript

  • Before installing typescript ,make sure to install node.js as we use npm to install typescript.
    Refer node.js on how to install node and npm

  • Once node.js is installed in your local machine , now let's carry on with typescript. From the terminal execute the following command in - npm install typescript --save-dev

    Note: For mac users insert a sudo before the above command - sudo npm install typescript --save-dev

  • Once the above command is executed, Typescript compiler will be installed in your local machine. This compiler will be used to compile typescript code to javascript code.

  • To execute typescript files use tsc command followed by the typescript file.
    Example: tsc <file-name>.ts

  • Compiling typescript using tsc is time consuming as we will have to run that command everytime a change occurs. Instead use --watch or -w along with the above command. Watch will make sure the file is compiled everytime a change occurs. To terminate watch mode press ctrl+c.
    Example: tsc <file-name>.ts --watch or tsc <file-name>.ts -w

  • Once the above command is executed successfully a javascript files with the sample will be generated.
    But the difference between the files is that all the types set in typescript file will not be present in javvascript file.

Typescript Compiler

  • For Compiling all the typescript files in a project or a folder we need to change the directory from the terminal where we run the project. Once directed to the folder run the command tsc --init. This will create a tsconfig.json file. Once it's created we can compile all the typescript files in a project or folder using tsc. We can also do it with watch mode: tsc --watch or tsc -w.

  • In order to exclude and include files from complilation we have two properties exclude and includes which needs to specified in the tsconfig.json file.
    "exclude":[file1.ts],"include":[file2.ts].
    Here, file1 will skip compilation whereas file2 will be complied to javascript. We can specify multiple files in the same directory or other folders.

  • In Compiler options there's some properties that will account for how the typescript files are compiled. Some of them are:

    1. target: This property specifies to what version of javascript the typescript files are complied to. The default target is es5.
    2. lib: Typescript supports both front-end and backened operations. But not all the functionalities are supported by typescript in default. To specify these default libraries or modules list them in the lib array.
    3. checkJs and allowJs: with allowJs typescript will compile jaavscript files and checkJs will throw errors, if present in javascript files.
    4. sourceMap: This provides a means through which typescript files are included in the filesystem for debugging purposes.
    5. outDir and rootDir: outDir is used to indicate a folder where all the compiled javascript files should be placed. rootDir indicates the root path of the typescript files to be compiled.
    6. removeComments: This property is enables true then the comments in .ts files will be removed in compiled javascript files.
    7. noEmit: This property makes sure the typescript files are not complied to javascript files upon getting any errors.
    8. noEmitOnError: This property will make sure none of the .ts files are compiled even if a error is found in any of the files.
    9. strict: makes sure the code quality is maintained and throws an error on any missed declaration etc.

Modules

  1. Typescript basics and types
  2. Classes and Interfaces
  3. Advanced typing concepts
  4. Generics
  5. Decorators

Note: To know more about typescript ,please do follow the typescript documentation