Этот материал находится в платной подписке. Оформи премиум подписку и смотри или слушай JavaScript - The Complete Guide 2022 (Beginner + Advanced), а также все другие курсы, прямо сейчас!
Премиум
  1. Урок 1. 00:01:51
    Introduction
  2. Урок 2. 00:03:47
    What is JavaScript?
  3. Урок 3. 00:09:09
    JavaScript in Action!
  4. Урок 4. 00:03:15
    How JavaScript Is Executed
  5. Урок 5. 00:03:29
    Dynamic vs Weakly Typed Languages
  6. Урок 6. 00:04:41
    JavaScript Executes In A Hosted Environment
  7. Урок 7. 00:06:01
    Course Outline - What's In This Course?
  8. Урок 8. 00:02:37
    How To Get The Most Out Of This Course
  9. Урок 9. 00:04:03
    JavaScript vs Java
  10. Урок 10. 00:06:04
    A Brief History Of JavaScript
  11. Урок 11. 00:11:13
    Setting Up a Development Environment
  12. Урок 12. 00:01:18
    Module Introduction
  13. Урок 13. 00:04:26
    Setting Up the Project
  14. Урок 14. 00:06:43
    Adding JavaScript to the Website
  15. Урок 15. 00:05:18
    Introducing Variables & Constants
  16. Урок 16. 00:07:11
    Declaring & Defining Variables
  17. Урок 17. 00:06:18
    Working with Variables & Operators
  18. Урок 18. 00:01:22
    Understanding the Starting Code
  19. Урок 19. 00:06:02
    Data Types: Numbers & Strings (Text)
  20. Урок 20. 00:05:12
    Using Constants
  21. Урок 21. 00:15:52
    More on Strings
  22. Урок 22. 00:05:51
    Introducing Functions
  23. Урок 23. 00:11:23
    Adding A Custom Function
  24. Урок 24. 00:04:32
    Returning Values
  25. Урок 25. 00:04:35
    The (Un)Importance of Code Order
  26. Урок 26. 00:05:32
    An Introduction to Global & Local Scope
  27. Урок 27. 00:02:25
    More about the "return" Statement
  28. Урок 28. 00:11:11
    Executing Functions "Indirectly"
  29. Урок 29. 00:06:15
    Converting Data Types
  30. Урок 30. 00:05:50
    Splitting Code into Functions
  31. Урок 31. 00:07:44
    Connecting all Buttons to Functions
  32. Урок 32. 00:04:10
    Working with Code Comments
  33. Урок 33. 00:06:40
    More Operators!
  34. Урок 34. 00:04:32
    More Core Data Types!
  35. Урок 35. 00:08:54
    Using Arrays
  36. Урок 36. 00:06:03
    Creating Objects
  37. Урок 37. 00:02:52
    Accessing Object Data
  38. Урок 38. 00:05:25
    Adding a Re-Usable Function That Uses Objects
  39. Урок 39. 00:06:21
    undefined, null & NaN
  40. Урок 40. 00:03:13
    The "typeof" Operator
  41. Урок 41. 00:14:38
    Importing Scripts Correctly with "defer" & "async"
  42. Урок 42. 00:02:14
    Wrap Up
  43. Урок 43. 00:01:29
    Module Introduction
  44. Урок 44. 00:03:19
    Efficient Development & Debugging - An Overview
  45. Урок 45. 00:02:26
    Configuring the IDE Look & Feel
  46. Урок 46. 00:04:13
    Using Shortcuts
  47. Урок 47. 00:04:35
    Working with Auto-Completion & IDE Hints
  48. Урок 48. 00:02:05
    Installing IDE Extensions
  49. Урок 49. 00:02:16
    Tweaking Editor Settings
  50. Урок 50. 00:01:43
    Utilizing Different IDE Views
  51. Урок 51. 00:05:54
    Finding Help & Working with MDN
  52. Урок 52. 00:01:46
    How to "google" Correctly
  53. Урок 53. 00:03:18
    Debugging JavaScript - An Overview
  54. Урок 54. 00:04:47
    An Error Message! No Reason To Panic!
  55. Урок 55. 00:03:50
    Using console.log() to look "into the Code"
  56. Урок 56. 00:08:21
    Next-Level Debugging with the Chrome Devtools & Breakpoints
  57. Урок 57. 00:02:06
    Testing Code Changes Directly in the Devtools
  58. Урок 58. 00:04:56
    Debugging Code directly Inside VS Code
  59. Урок 59. 00:01:23
    Wrap Up
  60. Урок 60. 00:09:18
    Module Introduction
  61. Урок 61. 00:09:27
    Introducing "if" Statements & Boolean (Comparison) Operators
  62. Урок 62. 00:07:24
    Using "if" Statements
  63. Урок 63. 00:05:11
    Working with "if", "else" and "else-if"
  64. Урок 64. 00:04:07
    Beware When Comparing Objects & Arrays for Equality!
  65. Урок 65. 00:09:11
    The Logical AND and OR Operators
  66. Урок 66. 00:07:21
    Understanding Operator Precedence
  67. Урок 67. 00:07:31
    Beyond true/ false: "Truthy" and "Falsy" Values
  68. Урок 68. 00:03:00
    Setting Up a Bigger Example Project (The "Monster Killer")
  69. Урок 69. 00:07:58
    Adding an "Attack" Function
  70. Урок 70. 00:09:18
    Using "if" Statements for Checking the Win-Condition
  71. Урок 71. 00:07:42
    Adding More "if" Statements & A "Strong Attack" Functionality
  72. Урок 72. 00:10:16
    Time for a "Heal Player" Functionality!
  73. Урок 73. 00:06:01
    Controlling the Conditional Bonus Life (Without Boolean Operators!)
  74. Урок 74. 00:06:01
    Adding a "Reset Game" Functionality
  75. Урок 75. 00:06:18
    Validating User Input
  76. Урок 76. 00:03:21
    Utilizing Global Constants as Identifiers in Conditional Code
  77. Урок 77. 00:16:38
    Adding a Conditional Battle Log
  78. Урок 78. 00:07:32
    Introducing the Ternary Operator
  79. Урок 79. 00:01:41
    A Bit of Theory: Statements vs Expressions
  80. Урок 80. 00:12:59
    Logical Operator "Tricks" & Shorthands
  81. Урок 81. 00:07:11
    Working with the "switch-case" Statement
  82. Урок 82. 00:06:41
    Introducing Loops
  83. Урок 83. 00:07:39
    The "for" Loop
  84. Урок 84. 00:05:18
    The "for-of" Loop
  85. Урок 85. 00:06:50
    The "for-in" Loop
  86. Урок 86. 00:08:01
    The "while" & "do-while" Loops
  87. Урок 87. 00:08:12
    Controlling Loops with "break"
  88. Урок 88. 00:02:22
    Controlling Iterations with "continue"
  89. Урок 89. 00:06:27
    More Control with Labeled Statements
  90. Урок 90. 00:02:26
    Error Handling with "try-catch" - An Introduction
  91. Урок 91. 00:05:18
    Throwing Custom Errors
  92. Урок 92. 00:08:15
    Working with "try-catch" to Catch & Handle Errors
  93. Урок 93. 00:03:22
    Wrap Up
  94. Урок 94. 00:01:44
    Module Introduction
  95. Урок 95. 00:08:15
    ES5 vs ES6+ ("Next Gen JS") - Evolution of JavaScript
  96. Урок 96. 00:14:33
    var vs let & const - Introducing "Block Scope"
  97. Урок 97. 00:04:08
    Understanding "Hoisting"
  98. Урок 98. 00:05:47
    Strict Mode & Writing Good Code
  99. Урок 99. 00:08:17
    How Code is Parsed & Compiled
  100. Урок 100. 00:16:00
    Inside the JavaScript Engine - How the Code Executes
  101. Урок 101. 00:19:25
    Primitive vs Reference Values
  102. Урок 102. 00:12:01
    Garbage Collection & Memory Management
  103. Урок 103. 00:01:56
    Wrap Up
  104. Урок 104. 00:01:32
    Module Introduction
  105. Урок 105. 00:01:53
    Recapping Functions Knowledge - What We Know Thus Far
  106. Урок 106. 00:05:47
    Functions vs Methods
  107. Урок 107. 00:02:48
    Functions are Objects!
  108. Урок 108. 00:05:13
    Function Expressions: Storing Functions in Variables
  109. Урок 109. 00:02:48
    Function Expressions vs Function Declarations
  110. Урок 110. 00:05:55
    Anonymous Functions
  111. Урок 111. 00:07:45
    Working on the Project: Adding User Choices to the Game
  112. Урок 112. 00:07:21
    Implementing the Core Game Logic
  113. Урок 113. 00:08:42
    Introducing Arrow Functions
  114. Урок 114. 00:03:55
    Outputting Messages to the User
  115. Урок 115. 00:10:46
    Default Arguments in Functions
  116. Урок 116. 00:08:58
    Introducing Rest Parameters ("Rest Operator")
  117. Урок 117. 00:03:05
    Creating Functions Inside of Functions
  118. Урок 118. 00:06:10
    Understanding Callback Functions
  119. Урок 119. 00:08:40
    Working with "bind()"
  120. Урок 120. 00:03:48
    Adding bind() to the Calculator Project
  121. Урок 121. 00:01:19
    call() and apply()
  122. Урок 122. 00:02:11
    Wrap Up
  123. Урок 123. 00:01:49
    Module Introduction
  124. Урок 124. 00:06:01
    What's the "DOM"?
  125. Урок 125. 00:06:21
    Document and Window Object
  126. Урок 126. 00:07:08
    Understanding the DOM and how it's created
  127. Урок 127. 00:05:56
    Nodes & Elements - Querying the DOM Overview
  128. Урок 128. 00:09:55
    Selecting Elements in the DOM
  129. Урок 129. 00:07:39
    Exploring and Changing DOM Properties
  130. Урок 130. 00:08:59
    Attributes vs Properties
  131. Урок 131. 00:05:14
    Selecting Multiple Elements & Summary
  132. Урок 132. 00:06:23
    Traversing the DOM - Overview
  133. Урок 133. 00:09:16
    Traversing Child Nodes
  134. Урок 134. 00:05:02
    Using parentNode & parentElement
  135. Урок 135. 00:04:07
    Selecting Sibling Elements
  136. Урок 136. 00:04:36
    DOM Traversal vs Query Methods
  137. Урок 137. 00:12:19
    Styling DOM Elements
  138. Урок 138. 00:02:43
    Creating Elements with JS - Overview
  139. Урок 139. 00:07:43
    Adding Elements via HTML in Code
  140. Урок 140. 00:05:43
    Adding Elements via createElement()
  141. Урок 141. 00:08:16
    Inserting DOM Elements
  142. Урок 142. 00:01:46
    Cloning DOM Nodes
  143. Урок 143. 00:04:56
    Live Node Lists vs Static Node Lists
  144. Урок 144. 00:01:57
    Removing Elements
  145. Урок 145. 00:02:39
    Insertion & Removal Method Summary
  146. Урок 146. 00:02:17
    Setting Up the Practice Project
  147. Урок 147. 00:08:59
    Selecting the Modal and "Add" Button
  148. Урок 148. 00:05:02
    Opening a Modal by Changing CSS Classes
  149. Урок 149. 00:08:05
    Controlling the Backdrop
  150. Урок 150. 00:08:07
    Fetching and Validating User Input
  151. Урок 151. 00:04:02
    Creating a Movie in JavaScript & Clearing the Input
  152. Урок 152. 00:08:25
    Rendering Movie Items on the Screen
  153. Урок 153. 00:09:13
    Deleting Movie Elements
  154. Урок 154. 00:07:09
    Showing & Hiding the "Are you sure?" Dialog
  155. Урок 155. 00:04:30
    Starting with the Confirmation Logic
  156. Урок 156. 00:11:46
    Finishing the App
  157. Урок 157. 00:01:56
    Wrap Up
  158. Урок 158. 00:01:09
    Module Introduction
  159. Урок 159. 00:02:12
    What are "Iterables" and "Array-like Objects"?
  160. Урок 160. 00:08:57
    Creating Arrays
  161. Урок 161. 00:03:48
    Which Data Can You Store In Arrays?
  162. Урок 162. 00:07:00
    push(), pop(), unshift(), shift() - Adding & Removing Elements
  163. Урок 163. 00:05:39
    The splice() Method
  164. Урок 164. 00:06:07
    Selecting Ranges & Creating Copies with slice()
  165. Урок 165. 00:02:24
    Adding Arrays to Arrays with concat()
  166. Урок 166. 00:03:48
    Retrieving Indexes with indexOf() /& lastIndexOf()
  167. Урок 167. 00:05:21
    Finding Stuff: find() and findIndex()
  168. Урок 168. 00:01:21
    Is it Included?
  169. Урок 169. 00:04:26
    Alternative to for Loops: The forEach() Method
  170. Урок 170. 00:02:39
    Transforming Data with map()
  171. Урок 171. 00:04:17
    sort()ing and reverse()ing
  172. Урок 172. 00:02:36
    Filtering Arrays with filter()
  173. Урок 173. 00:01:32
    Where Arrow Functions Shine!
  174. Урок 174. 00:07:34
    The Important reduce() Method
  175. Урок 175. 00:04:22
    Arrays & Strings - split() and join()
  176. Урок 176. 00:10:32
    The Spread Operator (...)
  177. Урок 177. 00:04:26
    Understanding Array Destructuring
  178. Урок 178. 00:04:17
    Maps & Sets - Overview
  179. Урок 179. 00:07:22
    Working with Sets
  180. Урок 180. 00:09:31
    Working with Maps
  181. Урок 181. 00:03:42
    Maps vs Objects
  182. Урок 182. 00:04:51
    Understanding WeakSet
  183. Урок 183. 00:02:52
    Understanding WeakMap
  184. Урок 184. 00:01:26
    Wrap Up
  185. Урок 185. 00:01:39
    Module Introduction
  186. Урок 186. 00:05:55
    What's an Object?
  187. Урок 187. 00:02:43
    Objects - Recap
  188. Урок 188. 00:06:47
    Adding, Modifying & Deleting Properties
  189. Урок 189. 00:08:37
    Special Key Names & Square Bracket Property Access
  190. Урок 190. 00:03:56
    Property Types & Property Order
  191. Урок 191. 00:04:12
    Dynamic Property Access & Setting Properties Dynamically
  192. Урок 192. 00:09:23
    Demo App & Shorthand Property Syntax
  193. Урок 193. 00:05:37
    Rendering Elements based on Objects
  194. Урок 194. 00:05:25
    for-in Loops & Outputting Dynamic Properties
  195. Урок 195. 00:05:39
    Adding the Filter Functionality
  196. Урок 196. 00:01:52
    Understanding "Chaining" (Property & Method Chaining)
  197. Урок 197. 00:05:55
    The Object Spread Operator (...)
  198. Урок 198. 00:02:09
    Understanding Object.assign()
  199. Урок 199. 00:06:14
    Object Destructuring
  200. Урок 200. 00:02:43
    Checking for Property Existance
  201. Урок 201. 00:05:53
    Introducing "this"
  202. Урок 202. 00:01:08
    The Method Shorthand Syntax
  203. Урок 203. 00:05:42
    The "this" Keyword And Its Strange Behavior
  204. Урок 204. 00:03:23
    call() and apply()
  205. Урок 205. 00:02:34
    What the Browser (Sometimes) Does to "this"
  206. Урок 206. 00:10:37
    "this" and Arrow Functions
  207. Урок 207. 00:07:06
    Getters & Setters
  208. Урок 208. 00:01:35
    Wrap Up
  209. Урок 209. 00:01:56
    Module Introduction
  210. Урок 210. 00:03:18
    What is "Object-oriented Programming" (OOP)?
  211. Урок 211. 00:12:11
    Getting Started with OOP Code
  212. Урок 212. 00:07:18
    Defining & Using a First Class
  213. Урок 213. 00:04:52
    Working with Constructor Methods
  214. Урок 214. 00:02:20
    Fields vs Properties
  215. Урок 215. 00:09:07
    Using & "Connecting" Multiple Classes
  216. Урок 216. 00:04:58
    Binding Class Methods & Working with "this"
  217. Урок 217. 00:04:38
    Adding a Cart and Shop Class
  218. Урок 218. 00:03:55
    Communicating Can Be Challenging!
  219. Урок 219. 00:07:52
    Static Methods & Properties
  220. Урок 220. 00:04:07
    First Summary & Classes vs Object Literals
  221. Урок 221. 00:05:44
    Getters & Setters
  222. Урок 222. 00:02:35
    Introducing Inheritance
  223. Урок 223. 00:11:51
    Implementing Inheritance
  224. Урок 224. 00:06:52
    Using Inheritance Everywhere
  225. Урок 225. 00:06:01
    Overriding Methods and the super() Constructor
  226. Урок 226. 00:06:47
    super() Constructor Execution, Order & "this"
  227. Урок 227. 00:05:52
    Different Ways of Adding Methods
  228. Урок 228. 00:07:25
    Private Properties
  229. Урок 229. 00:04:31
    The "instanceof" Operator
  230. Урок 230. 00:01:10
    Built-in Classes
  231. Урок 231. 00:07:36
    Understanding Object Descriptors
  232. Урок 232. 00:01:52
    Wrap Up
  233. Урок 233. 00:01:35
    Module Introduction
  234. Урок 234. 00:04:03
    Introducing Constructor Functions
  235. Урок 235. 00:04:18
    Constructor Functions vs Classes & Understanding "new"
  236. Урок 236. 00:16:48
    Introducing Prototypes
  237. Урок 237. 00:05:20
    Working with Prototypes
  238. Урок 238. 00:08:27
    The Prototype Chain and the Global "Object"
  239. Урок 239. 00:05:25
    Classes & Prototypes
  240. Урок 240. 00:10:17
    Methods in Classes & In Constructors
  241. Урок 241. 00:02:13
    Built-in Prototypes in JavaScript
  242. Урок 242. 00:10:59
    Setting & Getting Prototypes
  243. Урок 243. 00:02:50
    Wrap Up
  244. Урок 244. 00:01:39
    Module Introduction
  245. Урок 245. 00:04:47
    First Project Steps & Planning
  246. Урок 246. 00:04:09
    Creating Project Lists & Parsing Element Data
  247. Урок 247. 00:10:00
    Starting with the "Switch Project" Logic
  248. Урок 248. 00:07:03
    Passing Method References Around
  249. Урок 249. 00:11:50
    Moving DOM Elements
  250. Урок 250. 00:08:59
    Adding a Tooltip
  251. Урок 251. 00:06:14
    Adding Inheritance
  252. Урок 252. 00:00:58
    Wrap Up
  253. Урок 253. 00:02:32
    Module Introduction
  254. Урок 254. 00:06:52
    Using "dataset" (data-* Attributes)
  255. Урок 255. 00:05:55
    Getting Element Box Dimensions
  256. Урок 256. 00:04:57
    Working with Element Sizes & Positions
  257. Урок 257. 00:02:22
    The DOM & Prototypes
  258. Урок 258. 00:10:58
    Positioning the Tooltip
  259. Урок 259. 00:05:38
    Handling Scrolling
  260. Урок 260. 00:05:15
    Working with <template> Tags
  261. Урок 261. 00:07:36
    Loading Scripts Dynamically
  262. Урок 262. 00:07:38
    Setting Timers & Intervals
  263. Урок 263. 00:04:21
    The "location" and "history" Objects
  264. Урок 264. 00:04:51
    The "navigator" Object
  265. Урок 265. 00:03:18
    Working with Dates
  266. Урок 266. 00:03:22
    The "Error" Object & Constructor Function
  267. Урок 267. 00:00:44
    Wrap Up
  268. Урок 268. 00:01:32
    Module Introduction
  269. Урок 269. 00:06:19
    Introduction to Events in JavaScript
  270. Урок 270. 00:07:00
    Different Ways of Listening to Events
  271. Урок 271. 00:05:15
    Removing Event Listeners
  272. Урок 272. 00:05:44
    The "event" Object
  273. Урок 273. 00:08:02
    Supported Event Types
  274. Урок 274. 00:05:16
    Working with "preventDefault()"
  275. Урок 275. 00:02:04
    Understanding "Capturing" & "Bubbling" Phases
  276. Урок 276. 00:07:40
    Event Propagation & "stopPropagation()"
  277. Урок 277. 00:08:34
    Using Event Delegation
  278. Урок 278. 00:03:41
    Triggering DOM Elements Programmatically
  279. Урок 279. 00:02:29
    Event Handler Functions & "this"
  280. Урок 280. 00:05:00
    Drag & Drop - Theory
  281. Урок 281. 00:06:24
    Configuring Draggable Elements
  282. Урок 282. 00:08:53
    Marking the "Drop Area"
  283. Урок 283. 00:06:59
    Dropping & Moving Data + Elements
  284. Урок 284. 00:01:16
    Wrap Up
  285. Урок 285. 00:00:58
    Module Introduction
  286. Урок 286. 00:06:14
    Pure Functions & Side-Effects
  287. Урок 287. 00:02:01
    Impure vs Pure Functions
  288. Урок 288. 00:05:42
    Factory Functions
  289. Урок 289. 00:07:46
    Closures
  290. Урок 290. 00:07:02
    Closures in Practice
  291. Урок 291. 00:01:25
    Closures & Memory Management
  292. Урок 292. 00:07:33
    Introducing "Recursion"
  293. Урок 293. 00:09:02
    Advanced Recursion
  294. Урок 294. 00:01:15
    Wrap Up
  295. Урок 295. 00:00:54
    Module Introduction
  296. Урок 296. 00:07:47
    How Numbers Work & Behave in JavaScript
  297. Урок 297. 00:11:05
    Floating Point (Im)Precision
  298. Урок 298. 00:03:37
    The BigInt Type
  299. Урок 299. 00:02:48
    The Global "Number" and "Math" Objects
  300. Урок 300. 00:05:34
    Example: Generate Random Number Between Min/ Max
  301. Урок 301. 00:01:44
    Exploring String Methods
  302. Урок 302. 00:10:30
    Tagged Templates
  303. Урок 303. 00:04:32
    Introducing Regular Expressions ("RegEx")
  304. Урок 304. 00:07:26
    More on Regular Expressions
  305. Урок 305. 00:01:21
    Wrap Up
  306. Урок 306. 00:01:13
    Module Introduction
  307. Урок 307. 00:02:52
    Understanding Synchronous Code Execution ("Sync Code")
  308. Урок 308. 00:05:45
    Understanding Asynchronous Code Execution ("Async Code")
  309. Урок 309. 00:10:31
    Blocking Code & The "Event Loop"
  310. Урок 310. 00:04:04
    Sync + Async Code - The Execution Order
  311. Урок 311. 00:03:21
    Multiple Callbacks & setTimeout(0)
  312. Урок 312. 00:08:26
    Getting Started with Promises
  313. Урок 313. 00:05:54
    Chaining Multiple Promises
  314. Урок 314. 00:07:47
    Promise Error Handling
  315. Урок 315. 00:09:12
    Async/ await
  316. Урок 316. 00:03:08
    Async/ await & Error Handling
  317. Урок 317. 00:04:57
    Async/ await vs "Raw Promises"
  318. Урок 318. 00:08:00
    Promise.all(), Promise.race() etc.
  319. Урок 319. 00:01:28
    Wrap Up
  320. Урок 320. 00:01:08
    Module Introduction
  321. Урок 321. 00:05:04
    What & Why
  322. Урок 322. 00:05:25
    More Background about Http
  323. Урок 323. 00:03:36
    Getting Started with Http
  324. Урок 324. 00:03:47
    Sending a GET Request
  325. Урок 325. 00:09:15
    JSON Data & Parsing Data
  326. Урок 326. 00:03:50
    Promisifying Http Requests (with XMLHttpRequest)
  327. Урок 327. 00:04:56
    Sending Data with a POST Request
  328. Урок 328. 00:03:14
    Triggering Requests via the UI
  329. Урок 329. 00:04:57
    Sending a DELETE Request
  330. Урок 330. 00:05:04
    Handling Errors
  331. Урок 331. 00:07:12
    Using the fetch() API
  332. Урок 332. 00:02:39
    POSTing Data with the fetch() API
  333. Урок 333. 00:03:02
    Adding Request Headers
  334. Урок 334. 00:07:13
    fetch() & Error Handling
  335. Урок 335. 00:01:43
    XMLHttpRequest vs fetch()
  336. Урок 336. 00:06:59
    Working with FormData
  337. Урок 337. 00:01:18
    Wrap Up
  338. Урок 338. 00:01:00
    Module Introduction
  339. Урок 339. 00:02:56
    What & Why
  340. Урок 340. 00:09:11
    Adding Libraries (Example: lodash)
  341. Урок 341. 00:02:31
    Example: jQuery
  342. Урок 342. 00:03:26
    Discovering Libraries
  343. Урок 343. 00:10:47
    Axios Library & Http Requests
  344. Урок 344. 00:04:55
    Third-Party Library Considerations
  345. Урок 345. 00:01:00
    Wrap Up
  346. Урок 346. 00:00:57
    Module Introduction
  347. Урок 347. 00:07:13
    Splitting Code in a Sub-optimal Way
  348. Урок 348. 00:03:26
    A First Step Towards JavaScript Modules
  349. Урок 349. 00:05:59
    We Need a Development Server!
  350. Урок 350. 00:03:42
    First import / export Work
  351. Урок 351. 00:04:27
    Switching All Files To Use Modules
  352. Урок 352. 00:06:13
    More Named Export Syntax Variations
  353. Урок 353. 00:03:36
    Working With Default Exports
  354. Урок 354. 00:05:25
    Dynamic Imports & Code Splitting
  355. Урок 355. 00:02:07
    When Does Module Code Execute?
  356. Урок 356. 00:06:19
    Module Scope & globalThis
  357. Урок 357. 00:01:38
    Wrap Up
  358. Урок 358. 00:03:24
    Module Introduction
  359. Урок 359. 00:08:12
    Project Limitations & Why We Need Tools
  360. Урок 360. 00:02:43
    Workflow Overview
  361. Урок 361. 00:03:47
    Setting Up a npm Project
  362. Урок 362. 00:03:40
    Working with npm Packages
  363. Урок 363. 00:08:39
    Linting with ESLint
  364. Урок 364. 00:15:14
    Bundling with Webpack
  365. Урок 365. 00:04:01
    Development Mode & Fixing "Lazy Loading"
  366. Урок 366. 00:03:15
    Using webpack-dev-server
  367. Урок 367. 00:03:06
    Generating Sourcemaps
  368. Урок 368. 00:03:46
    Building For Production
  369. Урок 369. 00:06:36
    Final Optimizations
  370. Урок 370. 00:04:07
    Using Third Party Packages with npm & Webpack
  371. Урок 371. 00:01:40
    Wrap Up
  372. Урок 372. 00:01:07
    Module Introduction
  373. Урок 373. 00:07:22
    Browser Storage Options
  374. Урок 374. 00:10:44
    localStorage & sessionStorage
  375. Урок 375. 00:06:07
    Getting Started with Cookies
  376. Урок 376. 00:08:11
    Working with Cookies
  377. Урок 377. 00:08:56
    Getting Started with IndexedDB
  378. Урок 378. 00:04:07
    Working with IndexedDB
  379. Урок 379. 00:00:49
    Wrap Up
  380. Урок 380. 00:01:30
    Module Introduction
  381. Урок 381. 00:07:37
    What Is "Browser Support" About?
  382. Урок 382. 00:08:21
    Determining Browser Support For A JavaScript Feature
  383. Урок 383. 00:03:30
    Determining Required Support
  384. Урок 384. 00:09:56
    Solution: Feature Detection + Fallback Code
  385. Урок 385. 00:03:19
    Solution: Using Polyfills
  386. Урок 386. 00:12:03
    Solution: Transpiling Code
  387. Урок 387. 00:11:03
    Improvement: Automatically Detect + Add Polyfills
  388. Урок 388. 00:00:59
    What about Support Outside of Browsers?
  389. Урок 389. 00:02:37
    Browser Support Outside of JavaScript Files
  390. Урок 390. 00:01:19
    Wrap Up
  391. Урок 391. 00:00:54
    Module Introduction
  392. Урок 392. 00:03:06
    Setting Up the Project
  393. Урок 393. 00:04:34
    Getting DOM Access
  394. Урок 394. 00:06:28
    Getting the User Location
  395. Урок 395. 00:11:17
    Adding Feedback (Showing a Modal)
  396. Урок 396. 00:02:39
    Hiding the Modal
  397. Урок 397. 00:14:17
    Rendering a Map with Google Maps
  398. Урок 398. 00:08:23
    Finding an Address & Getting the Coordinates
  399. Урок 399. 00:03:36
    Converting User Input to Coordinates
  400. Урок 400. 00:08:32
    Creating a "Share Place" Link
  401. Урок 401. 00:03:37
    Copying the Link to the Clipboard
  402. Урок 402. 00:06:23
    Rendering the "Shared Place" Screen
  403. Урок 403. 00:01:07
    Module Introduction
  404. Урок 404. 00:07:36
    What and Why?
  405. Урок 405. 00:02:47
    The Idea Behind React.js
  406. Урок 406. 00:17:39
    Analysing a React Project
  407. Урок 407. 00:01:36
    Wrap Up
  408. Урок 408. 00:01:52
    Module Introduction
  409. Урок 409. 00:08:28
    Understanding Symbols
  410. Урок 410. 00:05:16
    Well-known Symbols
  411. Урок 411. 00:05:33
    Understanding Iterators
  412. Урок 412. 00:11:03
    Generators & Iterable Objects
  413. Урок 413. 00:03:23
    Generators Summary & Built-in Iterables Examples
  414. Урок 414. 00:07:11
    The Reflect API
  415. Урок 415. 00:09:05
    The Proxy API and a First "Trap"
  416. Урок 416. 00:02:58
    Working with Proxy Traps
  417. Урок 417. 00:01:38
    Wrap Up
  418. Урок 418. 00:01:43
    Module Introduction
  419. Урок 419. 00:02:22
    JavaScript is a Hosted Language
  420. Урок 420. 00:06:18
    Installation & Basics
  421. Урок 421. 00:04:40
    Understanding Modules & File Access
  422. Урок 422. 00:05:47
    Working with Incoming Http Requests
  423. Урок 423. 00:04:02
    Sending Responses (HTML Data)
  424. Урок 424. 00:10:54
    Parsing Incoming Data
  425. Урок 425. 00:02:49
    Introducing & Installing Express.js
  426. Урок 426. 00:06:35
    Express.js: The Basics
  427. Урок 427. 00:04:24
    Extracting Data
  428. Урок 428. 00:06:53
    Rendering Server-side HTML with Templates & EJS
  429. Урок 429. 00:03:45
    Enhancing Our Project
  430. Урок 430. 00:12:10
    Adding Basic REST Routes
  431. Урок 431. 00:05:14
    Understanding CORS (Cross Origin Resource Sharing)
  432. Урок 432. 00:02:17
    Sending the Location ID to the Frontend
  433. Урок 433. 00:07:17
    Adding the GET Location Route
  434. Урок 434. 00:14:45
    Introducing MongoDB (Database)
  435. Урок 435. 00:01:51
    Wrap Up
  436. Урок 436. 00:01:36
    Module Introduction
  437. Урок 437. 00:06:46
    Security Hole Overview & Exposing Data in your Code
  438. Урок 438. 00:14:40
    Cross-Site Scripting Attacks (XSS)
  439. Урок 439. 00:05:18
    Third-Party Libraries & XSS
  440. Урок 440. 00:04:17
    CSRF Attacks (Cross Site Request Forgery)
  441. Урок 441. 00:02:54
    CORS (Cross Origin Resource Sharing)
  442. Урок 442. 00:01:32
    Wrap Up
  443. Урок 443. 00:01:12
    Module Introduction
  444. Урок 444. 00:07:30
    Deployment Steps
  445. Урок 445. 00:09:44
    Example: Static Host Deployment (no Server-side Code)
  446. Урок 446. 00:12:46
    Example: Dynamic Page Deployment (with Server-side Code)
  447. Урок 447. 00:01:50
    Module Introduction
  448. Урок 448. 00:06:17
    What is "Performance Optimization" About?
  449. Урок 449. 00:06:49
    Optimization Potentials
  450. Урок 450. 00:03:43
    Measuring Performance
  451. Урок 451. 00:15:31
    Diving Into The Browser Devtools (for Performance Measuring)
  452. Урок 452. 00:02:14
    Further Resources
  453. Урок 453. 00:04:04
    Preparing The Testing Setup
  454. Урок 454. 00:11:52
    Optimizing Startup Time & Code Usage / Coverage
  455. Урок 455. 00:09:54
    Updating The DOM Correctly
  456. Урок 456. 00:08:12
    Updating Lists Correctly
  457. Урок 457. 00:03:59
    Optimizing The Small Things
  458. Урок 458. 00:08:50
    Micro-Optimizations (Think Twice!)
  459. Урок 459. 00:09:44
    Finding & Fixing Memory Leaks
  460. Урок 460. 00:03:27
    Wrap Up
  461. Урок 461. 00:00:50
    Module Introduction
  462. Урок 462. 00:07:10
    What Is Testing? Why Does It Matter?
  463. Урок 463. 00:04:11
    Testing Setup
  464. Урок 464. 00:11:16
    Writing & Running Unit Tests
  465. Урок 465. 00:06:04
    Writing & Running Integration Tests
  466. Урок 466. 00:10:17
    Writing & Running e2e Tests
  467. Урок 467. 00:10:21
    Dealing with Async Code
  468. Урок 468. 00:07:52
    Working with Mocks
  469. Урок 469. 00:00:49
    Module Introduction
  470. Урок 470. 00:03:02
    What are Programming Paradigms?
  471. Урок 471. 00:08:54
    Procedural Programming in Practice
  472. Урок 472. 00:13:21
    Object Oriented Programming in Practice
  473. Урок 473. 00:13:53
    Functional Programming in Practice
  474. Урок 474. 00:03:27
    Wrap Up
  475. Урок 475. 00:02:03
    Module Introduction
  476. Урок 476. 00:04:23
    What are "Data Structures" & "Algorithms"?
  477. Урок 477. 00:10:23
    A First Example
  478. Урок 478. 00:07:27
    Solving the Same Problem Differently
  479. Урок 479. 00:11:45
    Performance & The "Big O" Notation
  480. Урок 480. 00:03:37
    More Time Complexities & Comparing Algorithms
  481. Урок 481. 00:05:24
    More on Big O
  482. Урок 482. 00:10:16
    More Examples
  483. Урок 483. 00:12:08
    Diving into Data Structures & Time Complexities
  484. Урок 484. 00:03:24
    Where to Learn More & Wrap Up
  485. Урок 485. 00:01:12
    Module Introduction
  486. Урок 486. 00:04:59
    What is TypeScript and Why would you use it?
  487. Урок 487. 00:10:06
    Working with Types
  488. Урок 488. 00:17:27
    Core Types & Diving Deeper
  489. Урок 489. 00:09:23
    Object Types, Array Types & Function Types
  490. Урок 490. 00:09:21
    Advanced Types (Literal Types, Union Types, Enums)
  491. Урок 491. 00:12:03
    Classes & Interfaces
  492. Урок 492. 00:05:03
    Generic Types
  493. Урок 493. 00:05:12
    Configuring the TypeScript Compiler
  494. Урок 494. 00:02:02
    Module Introduction
  495. Урок 495. 00:06:31
    Web Components in Action
  496. Урок 496. 00:03:23
    What are Web Components?
  497. Урок 497. 00:02:45
    Why Web Components?
  498. Урок 498. 00:04:57
    Getting Started!
  499. Урок 499. 00:02:45
    Web Component Browser Support
  500. Урок 500. 00:03:54
    Our Development Setup
  501. Урок 501. 00:08:19
    A First Custom Element
  502. Урок 502. 00:05:05
    Interacting with the Surrounding DOM
  503. Урок 503. 00:02:52
    Understanding the Custom Element Lifecycle
  504. Урок 504. 00:02:06
    Using "connectedCallback" for DOM Access
  505. Урок 505. 00:09:14
    Listening to Events Inside the Component
  506. Урок 506. 00:04:46
    Using Attributes on Custom Elements
  507. Урок 507. 00:04:09
    Styling our Elements
  508. Урок 508. 00:05:01
    Working with the "Shadow DOM"
  509. Урок 509. 00:05:42
    Adding an HTML Template
  510. Урок 510. 00:01:51
    Using Slots
  511. Урок 511. 00:03:22
    Defining the Template in JavaScript
  512. Урок 512. 00:02:41
    Using Style Tags in the Shadow DOM
  513. Урок 513. 00:07:34
    Extending Built-in Elements
  514. Урок 514. 00:00:50
    The Next Steps
  515. Урок 515. 00:02:27
    Understanding Shadow DOM Projection
  516. Урок 516. 00:03:46
    Styling "slot" Content Outside of the Shadow DOM
  517. Урок 517. 00:03:11
    Styling "slot" Content Inside of the Shadow DOM
  518. Урок 518. 00:04:43
    Styling the Host Component
  519. Урок 519. 00:02:50
    Conditional Host Styling
  520. Урок 520. 00:02:29
    Styling with the Host Content in Mind
  521. Урок 521. 00:06:21
    Smart Dynamic Styling with CSS Variables
  522. Урок 522. 00:03:23
    Cleaning Up the Overall Styling
  523. Урок 523. 00:06:18
    Observing Attribute Changes
  524. Урок 524. 00:02:35
    Adjusting the Component Behavior Upon Attribute Changes
  525. Урок 525. 00:06:11
    Using "disconnectedCallback"
  526. Урок 526. 00:06:14
    Adding a render() Method
  527. Урок 527. 00:00:53
    The Next Steps
  528. Урок 528. 00:06:34
    Creating the Basic Modal Component
  529. Урок 529. 00:02:31
    Adding the Modal Container
  530. Урок 530. 00:05:36
    Styling the Modal Elements
  531. Урок 531. 00:03:50
    Adding Some General App Logic
  532. Урок 532. 00:05:24
    Opening the Modal via CSS
  533. Урок 533. 00:06:38
    Public Methods & Properties
  534. Урок 534. 00:05:46
    Understanding Named Slots
  535. Урок 535. 00:05:11
    Listening to Slot Content Changes
  536. Урок 536. 00:06:58
    Closing the Modal
  537. Урок 537. 00:03:41
    Dispatching Custom Events
  538. Урок 538. 00:04:54
    Configuring Custom Events
  539. Урок 539. 00:04:52
    Finishing it up!
  540. Урок 540. 00:06:10
    Congratulations!