Facebook Pixel
Searching...
English
EnglishEnglish
EspañolSpanish
简体中文Chinese
FrançaisFrench
DeutschGerman
日本語Japanese
PortuguêsPortuguese
ItalianoItalian
한국어Korean
РусскийRussian
NederlandsDutch
العربيةArabic
PolskiPolish
हिन्दीHindi
Tiếng ViệtVietnamese
SvenskaSwedish
ΕλληνικάGreek
TürkçeTurkish
ไทยThai
ČeštinaCzech
RomânăRomanian
MagyarHungarian
УкраїнськаUkrainian
Bahasa IndonesiaIndonesian
DanskDanish
SuomiFinnish
БългарскиBulgarian
עבריתHebrew
NorskNorwegian
HrvatskiCroatian
CatalàCatalan
SlovenčinaSlovak
LietuviųLithuanian
SlovenščinaSlovenian
СрпскиSerbian
EestiEstonian
LatviešuLatvian
فارسیPersian
മലയാളംMalayalam
தமிழ்Tamil
اردوUrdu
A Smarter Way to Learn JavaScript. The new tech-assisted approach that requires half the effort

A Smarter Way to Learn JavaScript. The new tech-assisted approach that requires half the effort

by Mark Myers 2014 254 pages
4.05
500+ ratings
Listen

Key Takeaways

1. JavaScript basics: Variables, data types, and operators

JavaScript is literal-minded.

Variables and data types. JavaScript uses variables to store and manipulate data. Declare variables with var, let, or const. Basic data types include numbers, strings, booleans, null, and undefined. JavaScript is dynamically typed, allowing variables to change types.

Operators and expressions. Use arithmetic operators (+, -, *, /, %) for mathematical operations. Comparison operators (==, ===, !=, !==, <, >, <=, >=) compare values. Logical operators (&&, ||, !) combine or negate boolean expressions. The assignment operator (=) assigns values to variables.

  • String concatenation: Use + to join strings
  • Type coercion: JavaScript automatically converts types in some operations
  • Operator precedence: Use parentheses to control order of operations

2. Control structures: Conditional statements and loops

JavaScript has an inconvenient quirk: After a true case is found, JavaScript not only executes the statement(s) immediately below that case. It executes all the statements for all the cases below it.

Conditional statements. Use if, else if, and else to execute code based on conditions. The switch statement provides an alternative for multiple conditions, but remember to use break to prevent fall-through behavior.

Loops for repetitive tasks. for loops are ideal for known iteration counts. while loops continue until a condition is false. do...while loops ensure at least one execution. Use break to exit loops early and continue to skip iterations.

  • if statement structure: if (condition) { // code }
  • switch statement structure: switch(expression) { case value: // code; break; }
  • for loop structure: for (initialization; condition; update) { // code }
  • while loop structure: while (condition) { // code }

3. Functions: Defining, calling, and understanding scope

A function is a block of JavaScript that robotically does the same thing again and again, whenever you invoke its name.

Function basics. Define functions using the function keyword, followed by a name, parameters in parentheses, and code block in curly braces. Call functions by name with arguments. Use return to send values back to the caller.

Scope and closure. Variables declared inside functions are local to that function. Global variables are accessible everywhere. Closure allows inner functions to access outer function variables, creating powerful patterns for data privacy and module design.

  • Function declaration: function name(parameters) { // code }
  • Function expression: var name = function(parameters) { // code }
  • Arrow functions (ES6+): (parameters) => { // code }
  • Parameters vs. arguments: Parameters are in function definition, arguments are values passed when calling

4. Arrays and objects: Working with complex data structures

A variable can have any number of values, but only one at a time.

Arrays for ordered collections. Create arrays with square brackets. Access elements by index (zero-based). Use methods like push(), pop(), shift(), unshift(), and splice() to modify arrays. Iterate with for loops or forEach().

Objects for key-value pairs. Define objects with curly braces. Access properties with dot notation or square brackets. Use object methods to manipulate data. Create object constructors for reusable templates. Understand prototypes for inheritance.

  • Array methods: length, indexOf(), slice(), map(), filter(), reduce()
  • Object creation: Literal notation, constructor functions, ES6 classes
  • Object prototype: Shared properties and methods for efficiency
  • JSON: JavaScript Object Notation for data interchange

5. DOM manipulation: Interacting with HTML elements

The DOM is an organization chart, created automatically by the browser when your web page loads, for the whole web page.

Accessing elements. Use methods like getElementById(), getElementsByClassName(), getElementsByTagName(), and querySelector() to select elements. Traverse the DOM tree with properties like parentNode, childNodes, and siblings.

Modifying elements. Change content with innerHTML or textContent. Modify attributes with setAttribute(). Adjust styles with the style property. Create new elements with createElement() and add them to the document with appendChild() or insertBefore().

  • DOM node types: Element nodes, text nodes, attribute nodes
  • Modifying classes: classList.add(), classList.remove(), classList.toggle()
  • Event listeners: addEventListener() for dynamic interactions
  • Performance: Use document fragments for batch DOM updates

6. Event handling: Responding to user actions

A good website is an interactive website.

Event types. Common events include click, mouseover, keydown, submit, load, and resize. Understand event bubbling and capturing phases for proper handling.

Adding event listeners. Use addEventListener() to attach event handlers to elements. Remove listeners with removeEventListener() when no longer needed. Handle default behaviors with preventDefault() and stop event propagation with stopPropagation().

  • Event object: Contains information about the event (e.g., target element, mouse position)
  • Event delegation: Attach listeners to parent elements for efficiency
  • Custom events: Create and dispatch your own events for complex interactions
  • Debouncing and throttling: Optimize performance for frequent events (e.g., scroll, resize)

7. Browser control: Managing windows and navigation

JavaScript code doesn't care where it lives.

Window manipulation. Open new windows or tabs with window.open(). Control window size and position with options. Close windows programmatically with window.close(). Understand same-origin policy limitations.

Navigation and history. Redirect users with window.location.href. Manipulate browser history using history.pushState() and history.replaceState(). Handle navigation events with the popstate event listener.

  • Browser storage: localStorage and sessionStorage for client-side data persistence
  • Cookies: Set and read cookies for small data storage and tracking
  • AJAX and Fetch API: Make asynchronous requests to servers without page reloads
  • Cross-origin resource sharing (CORS): Understand security implications and proper implementation

8. Best practices: Code organization and efficiency

Commenting, as you know from your work with HTML and CSS, is a way to tell the browser to ignore certain portions of text that you include within the body of code.

Code structure. Organize code into logical modules or components. Use consistent naming conventions (e.g., camelCase for variables and functions). Keep functions small and focused on single tasks.

Performance optimization. Minimize DOM manipulation. Use event delegation for multiple similar elements. Avoid global variables. Leverage browser caching and minification for faster loading. Implement lazy loading for images and heavy content.

  • ESLint and Prettier: Use tools for consistent code style and error detection
  • Version control: Use Git for tracking changes and collaborating
  • Testing: Implement unit tests and integration tests for reliability
  • Documentation: Write clear comments and maintain up-to-date documentation for your code

Last updated:

Review Summary

4.05 out of 5
Average of 500+ ratings from Goodreads and Amazon.

A Smarter Way to Learn JavaScript receives mostly positive reviews for its beginner-friendly approach, short chapters, and interactive online exercises. Readers appreciate the repetition and practice, which help reinforce concepts. Many find it excellent for those new to programming, though some experienced developers consider it too basic. The book is praised for its clear explanations and building confidence, but criticized for not covering advanced topics or ES6. Some readers recommend supplementing with other resources for a comprehensive understanding of JavaScript.

Your rating:

About the Author

Mark Myers is a former Boston University lecturer who now focuses on developing interactive training and websites. He holds a Harvard degree and is dedicated to reducing the tedium of learning through technology and interactivity. Myers is the creator of the "A Smarter Way to Learn" series, which combines instructional books with online exercises. He manages the website ASmarterWayToLearn.com. Based in Taos, NM, Myers lives with his wife and three cats. His interests include cooking, reading, playing frisbee, and watching "Breaking Bad." His approach to teaching programming emphasizes repetition and practice to enhance learning retention.

Download PDF

To save this A Smarter Way to Learn JavaScript. The new tech-assisted approach that requires half the effort summary for later, download the free PDF. You can print it out, or read offline at your convenience.
Download PDF
File size: 0.31 MB     Pages: 10

Download EPUB

To read this A Smarter Way to Learn JavaScript. The new tech-assisted approach that requires half the effort summary on your e-reader device or app, download the free EPUB. The .epub digital book format is ideal for reading ebooks on phones, tablets, and e-readers.
Download EPUB
File size: 3.01 MB     Pages: 8
0:00
-0:00
1x
Dan
Andrew
Michelle
Lauren
Select Speed
1.0×
+
200 words per minute
Create a free account to unlock:
Requests: Request new book summaries
Bookmarks: Save your favorite books
History: Revisit books later
Ratings: Rate books & see your ratings
Unlock Unlimited Listening
🎧 Listen while you drive, walk, run errands, or do other activities
2.8x more books Listening Reading
Today: Get Instant Access
Listen to full summaries of 73,530 books. That's 12,000+ hours of audio!
Day 4: Trial Reminder
We'll send you a notification that your trial is ending soon.
Day 7: Your subscription begins
You'll be charged on Jan 25,
cancel anytime before.
Compare Features Free Pro
Read full text summaries
Summaries are free to read for everyone
Listen to summaries
12,000+ hours of audio
Unlimited Bookmarks
Free users are limited to 10
Unlimited History
Free users are limited to 10
What our users say
30,000+ readers
"...I can 10x the number of books I can read..."
"...exceptionally accurate, engaging, and beautifully presented..."
"...better than any amazon review when I'm making a book-buying decision..."
Save 62%
Yearly
$119.88 $44.99/year
$3.75/mo
Monthly
$9.99/mo
Try Free & Unlock
7 days free, then $44.99/year. Cancel anytime.
Settings
Appearance
Black Friday Sale 🎉
$20 off Lifetime Access
$79.99 $59.99
Upgrade Now →