JavaScript Advanced

JavaScript Advanced

This training gives a deeper understanding of JavaScript’s complicated features, syntax constructions and inner mechanisms. It will be useful for developers who already have experience in JavaScript.

Durată
36 ore
Tipul de curs
Pe net
Limba
Engleză
Durată
36 ore
Locație
Pe net
Limba
Engleză
Cod
WEB-024
Training pentru 7-8 sau mai multe persoane? Personalizați antrenamentele pentru nevoile dumneavoastră specifice
JavaScript Advanced
Durată
36 ore
Locație
Online
Limba
English
Cod
WEB-024
€ 850 *
Training pentru 7-8 sau mai multe persoane? Personalizați antrenamentele pentru nevoile dumneavoastră specifice

Descriere

This training gives a deeper understanding of JavaScript’s complicated features, syntax constructions and inner mechanisms. It will be useful for developers who already have experience in JavaScript but want to unlock the full potential of the language, and start to use various lesser known but still very interesting and helpful possibilities.

certificat
După finalizarea cursului, se eliberează un certificat
în formularul Luxoft Training

Obiective

After the training, the attendees will:

  • better understand JavaScript language;
  • get to know JavaScript types and type conversions in depth;
  • learn asynchronous programming;
  • use REST services and websockets to communicate with the server;
  • use workers and parallel programming;
  • use service workers for caching;
  • use functional and reactive programming.

Public țintă

Target Audience:

  • JavaScript developers
  • TypeScript developers
  • Web developers
  • NodeJS developers

Cerințe preliminare

Knowledge of JavaScript

Foaia de parcurs

JavaScript basics in depth 

  • Class Object
  • Object descriptors
  • Object methods
  • Prototype inheritance
  • Symbols
  • Iterators
  • Generators
  • Creating iterable objects
  • Async generators

JavaScript types in depth

  • Types overview
  • Type Number
  • Floating point and rounding problems
  • Type String
  • Type Boolean
  • Type conversions
  • Map, Set, WeakMap, WeakSet
  • BigInt
  • ArrayBuffer
  • Typed arrays
  • DataViews
  • Blobs
  • FileReader
  • Processing the uploaded files

Asynchronous programming 

  • Asynchronous calls
  • Using this in callbacks
  • Promise class
  • Promise exception handling
  • Methods all(), any(), race(), allSettled()
  • Promise cancellation with Promise.race()
  • Promise cancellation with AbortController
  • Async/await syntax
  • Async/await Syntax: Exception Handling
  • Async/await Syntax: top-level await
  • Async/await Syntax: Constraints
  • REST architecture
  • HTTP status codes
  • HTTP methods
  • Statelessness and Scalability
  • CRUD Operations and Rest Services
  • Returned Data Format: XML, JSON, XHTML
  • Fetch Function
  • Fetch with possibility to abort request
  • Axios library for REST calls
  • Handling Errors in Axios
  • Request Canceling in Axios
  • Axios Interceptors
  • WebSocket protocol
  • WebSocket in a Browser
  • WebSocket on server (Node.js)
  • When to Use WebSocket?

Workers and parallel programming 

  • Workers
  • Worker types
  • Worker APIs
  • Registering worker
  • Worker use cases
  • Service workers
  • Cache API
  • Registering Service worker
  • Service worker lifecycle
  • Service worker as a server proxy
  • Cache First strategy (Cache Falling Back to Network)
  • Network First strategy (Network Falling Back to Cache)
  • Stale-While-Revalidate strategy
  • Which strategy to use
  • Update cache on push message strategy
  • Update cache on background synchronization strategy

Functional programming

  • Functions as data
  • Function Arguments and Arguments Array
  • Functions as Methods
  • Call and apply methods
  • Binding a Function to an Object
  • Closures
  • Creating an encapsulated value through closure
  • Constructor function
  • Array functions: map/filter/reduce
  • Programming paradigms
  • Declarative versus imperative
  • Functional programming
  • High-ordered functions
  • Pure functions
  • Benefits of pure functions
  • Immutability
  • Immutability of objects: Spread Operator
  • Benefits of immutability
  • Immutable.js
  • Nested data structures in Immutable.js
  • Monads and functional composition
  • Function pipe()
  • Decomposition of the functions
  • Monads for SIMD operations
  • Partial application of the function
  • Currying
  • Null safety
  • Null Object Design Pattern
  • Maybe monad
  • Partially defined function
  • Rules of Good Code for Writing Functions
  • Functional Design Patterns
  • MVC design pattern with pure functions
  • Observer design pattern
  • Event sourcing design pattern
  • REDUX design pattern
  • REDUX DevTools
  • REDUX advantages
  • Reactive programming design pattern (RxJS)
  • Filter/map/take operators
  • MergeMap/ConcatMap/SwitchMap operators
  • Window/Buffer operators
  • Sample/Throttle/Debounce operators
  • Reactive programming benefits and use cases


Mai ai întrebări?
Conectați-văcu noi