Mô tả

Javascript is the language that modern developers need to know, and know well. Truly knowing Javascript will get you a job, and enable you to build quality web and server applications.

NOTE: This course includes information on ECMAScript 6 (ES6) the next version of Javascript!

In this course you will gain a deep understanding of Javascript, learn how Javascript works under the hood, and how that knowledge helps you avoid common pitfalls and drastically improve your ability to debug problems. You will find clarity in the parts that others, even experienced coders, may find weird, odd, and at times incomprehensible. You'll learn the beauty and deceptive power of this language that is at the forefront of modern software development today.

This course will cover such advanced concepts as objects and object literals, function expressions, prototypical inheritance, functional programming, scope chains, function constructors (plus new ES6 features), immediately invoked function expressions (IIFEs), call, apply, bind, and more.

We'll take a deep dive into the source code of popular frameworks such as jQuery and Underscore to see how you can use your understanding of Javascript to learn (and borrow) from other's good code.

Finally, you'll learn the foundations of how to build your own Javascript framework or library.

What you'll learn in this course will make you a better Javascript developer, and improve your abilities in AngularJS, NodeJS, jQuery, React, Ember, MongoDB, and all other Javascript-based technologies!

Learn to love Javascript, and code in it well.

Note: In this course you'll also get downloadable source code. You will often be provided with 'starter' code, giving you the base for you to start writing your code, and 'finished' code to compare your code to.

Bạn sẽ học được gì

Grasp how Javascript works and it's fundamental concepts

Write solid, good Javascript code

Understand advanced concepts such as closures, prototypal inheritance, IIFEs, and much more.

Drastically improve your ability to debug problems in Javascript.

Avoid common pitfalls and mistakes other Javascript coders make

Understand the source code of popular Javascript frameworks

Build your own Javascript framework or library

Yêu cầu

  • Basic Javascript knowledge (variables, loops, and basic functions - that's all the course expects you to know!)
  • A browser and text editor

Nội dung khoá học

13 sections

Getting Started

6 lectures
Introduction and The Goal of This Course
04:56
Setup
03:27
Setup (Visual Studio Code)
00:25
Big Words and Javascript
01:25
Watching this Course in High Definition
00:50
Understanding, Frameworks, and The Weird Parts
04:17

Execution Contexts and Lexical Environments

13 lectures
Conceptual Aside: Syntax Parsers, Execution Contexts, and Lexical Environments
07:35
Conceptual Aside: Name/Value Pairs and Objects
04:08
Downloading Source Code for This Course
00:38
The Global Environment and The Global Object
10:58
The Execution Context - Creation and Hoisting
09:43
Conceptual Aside: Javascript and 'undefined'
08:04
The Execution Context - Code Execution
02:54
Conceptual Aside: Single Threaded, Synchronous Execution
02:16
Function Invocation and the Execution Stack
08:06
Functions, Context, and Variable Environments
07:56
The Scope Chain
17:25
Scope, ES6, and let
04:18
What About Asynchronous Callbacks?
10:26

Types and Operators

11 lectures
Conceptual Aside: Types and Javascript
02:50
Primitive Types
05:17
Conceptual Aside: Operators
06:32
Operator Precedence and Associativity
14:14
Operator Precedence and Associativity Table
00:18
Conceptual Aside: Coercion
06:14
Comparison Operators
19:42
Equality Comparisons Table
00:18
Existence and Booleans
07:24
Default Values
07:51
Framework Aside: Default Values
07:11

Objects and Functions

23 lectures
Objects and the Dot
15:23
Objects and Object Literals
10:32
Framework Aside: Faking Namespaces
08:07
JSON and Object Literals
07:17
Functions are Objects
08:02
Function Statements and Function Expressions
20:32
Conceptual Aside: By Value vs By Reference
16:09
Objects, Functions, and 'this'
21:26
Conceptual Aside: Arrays - Collections of Anything
05:39
'arguments' and spread
12:00
Framework Aside: Function Overloading
04:43
Conceptual Aside: Syntax Parsers
02:25
Dangerous Aside: Automatic Semicolon Insertion
05:46
Framework Aside: Whitespace
04:25
Immediately Invoked Functions Expressions (IIFEs)
17:07
Framework Aside: IIFEs and Safe Code
08:05
Understanding Closures
11:09
Understanding Closures - Part 2
19:20
Framework Aside: Function Factories
12:24
Closures and Callbacks
08:26
call(), apply(), and bind()
20:54
Functional Programming
20:17
Functional Programming - Part 2
08:05

Object-Oriented Javascript and Prototypal Inheritance

4 lectures
Conceptual Aside: Classical vs Prototypal Inheritance
05:11
Understanding the Prototype
14:02
Everything is an Object (or a primitive)
05:46
Reflection and Extend
14:59

Building Objects

8 lectures
Function Constructors, 'new', and the History of Javascript
15:53
Function Constructors and '.prototype'
10:24
Dangerous Aside: 'new' and functions
04:16
Conceptual Aside: Built-In Function Constructors
10:32
Dangerous Aside: Built-In Function Constructors
03:57
Dangerous Aside: Arrays and for..in
03:16
Object.create and Pure Prototypal Inheritance
12:37
ES6 and Classes
06:27

Odds and Ends

4 lectures
Initialization
05:41
'typeof' , 'instanceof', and Figuring Out What Something Is
06:41
Strict Mode
05:51
Strict Mode Reference
00:21

Examining Famous Frameworks and Libraries

4 lectures
Learning From Other's Good Code
03:51
Deep Dive into Source Code: jQuery - Part 1
21:31
Deep Dive into Source Code: jQuery - Part 2
15:38
Deep Dive into Source Code: jQuery - Part 3
11:22

Let's Build a Framework / Library!

8 lectures
Requirements
02:57
Structuring Safe Code
03:07
Our Object and Its Prototype
09:17
Properties and Chainable Methods
16:58
Adding jQuery Support
05:22
Good Commenting
02:21
Let's Use Our Framework
08:11
A Side Note
00:32

EXTRA: TypeScript, ES6, and Transpiled Languages

2 lectures
TypeScript, ES6, and Transpiled Languages
04:33
Transpiled Languages References
00:38

EXTRA: Getting Ready for ECMAScript 6

2 lectures
Existing and Upcoming Features
00:54
ES6 Features Reference
00:12

EXTRA: ES6 In-Depth

2 lectures
ES6 In-Depth
00:07
Promises, Async, and Await
42:43

Conclusion

2 lectures
Learning to Love the Weird Parts
01:14
Bonus
00:41

Đánh giá của học viên

Chưa có đánh giá
Course Rating
5
0%
4
0%
3
0%
2
0%
1
0%

Bình luận khách hàng

Viết Bình Luận

Bạn đánh giá khoá học này thế nào?

image

Đăng ký get khoá học Udemy - Unica - Gitiho giá chỉ 50k!

Get khoá học giá rẻ ngay trước khi bị fix.