Слайд 2What should I know about GIT?
Source control
Branching
Merge
Rebase
Cherry pick
Stash
Tag
Etc.
data:image/s3,"s3://crabby-images/d80f2/d80f2b71735dba5df9b03a33e55ba204050bde7a" alt="What should I know about GIT? Source control Branching Merge Rebase Cherry pick Stash Tag Etc."
Слайд 4Why I should use Typescript?
Less bugs
Development performance
Features: type checking, autocompletion, source documentation
data:image/s3,"s3://crabby-images/0a682/0a682ed67df9373e9a4f38c267bd2c86452db7fb" alt="Why I should use Typescript? Less bugs Development performance Features: type checking,"
and etc.
Responsive support from the Typescript team
Starts and ends with JavaScript
Beautiful and elegant
Etc.
Слайд 5Getting started
https://nodejs.org/en/
npm install -g typescript (or install locally in dev dependencies)
tsc helloworld.ts
data:image/s3,"s3://crabby-images/36296/36296e1f2e953cae108a3ecaec81317097705bfe" alt="Getting started https://nodejs.org/en/ npm install -g typescript (or install locally in dev dependencies) tsc helloworld.ts"
Слайд 6How to compile
tsc helloworld.ts
tsconfig.json
data:image/s3,"s3://crabby-images/49178/49178d9f9dbfb2febb78aa15226b7fdf03c886bf" alt="How to compile tsc helloworld.ts tsconfig.json"
Слайд 7Settings
target
removeComments
outDir
sourceMap
outFile
files
Etc.
data:image/s3,"s3://crabby-images/0a160/0a160be0e43be1aad6420ccfe650462fdf276bf6" alt="Settings target removeComments outDir sourceMap outFile files Etc."
Слайд 8Variables
Use ES6 let and const to declare variables in Typescript.
let user: User
data:image/s3,"s3://crabby-images/d4c85/d4c85b1abce80eab1f23eb029d81474dc02e8ab5" alt="Variables Use ES6 let and const to declare variables in Typescript. let"
= new User();
const cardNumber: string = “**** **** **** 1111”;
Слайд 9Types
boolean
number
String
Object
Array
Tuple
enum
null
undefined
void
never
any
data:image/s3,"s3://crabby-images/789f4/789f48dc11d4edf67cd371b32bb79b977ce43ef0" alt="Types boolean number String Object Array Tuple enum null undefined void never any"
Слайд 10Type declaration
declare type primitive = number | string | boolean| null |
data:image/s3,"s3://crabby-images/3a3f4/3a3f4ca0006e55f7ed28e26f17b77e3860e77535" alt="Type declaration declare type primitive = number | string | boolean| null | undefined;"
undefined;
Слайд 12What should I know about classes in TS?
fields
methods
constructor
static fields and methods
private/public/protected
get/set
readonly
data:image/s3,"s3://crabby-images/4b055/4b05578650c2d44e9099b5f0e31e02c29bbbe8b6" alt="What should I know about classes in TS? fields methods constructor static"
Слайд 13Inheritance and abstract classes
basic inheritance mechanism in general the same as in
data:image/s3,"s3://crabby-images/06619/06619eafd84ee70bc2dd6c321cc7832649fa5267" alt="Inheritance and abstract classes basic inheritance mechanism in general the same as"
ES6
abstract class can’t be instantiated
but more concrete implementation can be
example: abstract Figure, concrete Square and Circle.
Слайд 14What should I know about interfaces in TS?
syntax
optional and readonly properties
implementation
Interface inheritance
Function
data:image/s3,"s3://crabby-images/38bb1/38bb1c43bebc405b440da25ba2fee38bbc13d447" alt="What should I know about interfaces in TS? syntax optional and readonly"
and array interfaces
Слайд 15Generics
Use generics when something should work with any data types.
You can use
data:image/s3,"s3://crabby-images/7f1a3/7f1a348b53337915e822c1e3e1bed78b23d1dc2e" alt="Generics Use generics when something should work with any data types. You"
them with functions, classes, interfaces.
Example: promisify, Map class.
Слайд 16Namespaces
Namespaces contains a group of classes, functions, interfaces, variables, other namespaces, etc.
Use
data:image/s3,"s3://crabby-images/51b44/51b44339fbd5a357b897131dc37209d9a1dd4067" alt="Namespaces Namespaces contains a group of classes, functions, interfaces, variables, other namespaces,"
namespace to declare namespaces.
Use exports for using entities in other namespaces.
Слайд 17Modules
TS support the following modules:
AMD (Asynchronys Module Defenition)
CommonJS
UMD (Universal Module Defenition)
System
ES 2015
Use
data:image/s3,"s3://crabby-images/112cf/112cf54add201deb15651e7e139033935f8bbd69" alt="Modules TS support the following modules: AMD (Asynchronys Module Defenition) CommonJS UMD"
export/import features.
Example: User and UserService
Слайд 18Decorators
Allow to add metadata to classes or their members for changing their
data:image/s3,"s3://crabby-images/6fd56/6fd56adc28b2652621b45f5053185441d8da510f" alt="Decorators Allow to add metadata to classes or their members for changing"
behavior without changing their code.
Decorator – function, which can apply on class, field, methods, getter, setter, parameters, etc.
Set experimentalDecorators: true for using decorators.