Beginning With JavaScript
First things first. I HIGHLY recommend that you purchase this book: Learning JavaScript & its companion site with errata HERE (Clears up a lot of the negative review complaints). Additionally, I will recommend the “You don’t know JS” free online books as great resources to help you learn JavaScript. I will link to specific chapters for various topics below.
I teach an Introduction to Programming Logic class for a community college as well as for a semester at our high school. I use JavaScript for this class only insofar as to allow the students to test their algorithms and understand the coding process. I don’t teach any language features other than what are strictly needed to perform the coding projects, for example the library readline-sync
so they can read input from the command line. This is the order I use for my students, over a 16-week period:
- Code layout - Simply how to format each program file they will turn in for grading. I teach four sections: 1. Comment header, pragmas, & library imports; 2. Global variable declarations & constant declarations/initializations; 3. dispatching section using a main function; 4. All methods - Mutators & workers. Every project my students turn in follow that code layout pattern.
- Syntax and style - How we will format the code and what the language reserved words are.
- Comments - Single-line, multi-line, and JSDoc.
- Variables, constants, & scope - Data type, declaring, & initializing.
- Operators - <, >, ===, !==, <=, >=, arithmetic: + - * / % **
- Synchronous functions - How to modularize their code into smaller, cohesive chunks. This includes how to use dispatching with a main function.
- Parameters - How to pass & receive values into functions.
- Selection logic - If, else if, else.
- Boolean logic - AND (&&), OR (||) , NOT (!).
- Recursion - How to do it, why to limit it, and tail recursion.
- Looping - While, c-style for, ‘for of’, nesting loops, break & continue.
- Regular expressions - Primarily used for the next step.
- Input validation, sanitization, & distillation.
- Basic collections - Single & multi-dimensional arrays, maps, & sorting.
- File I/O - How to read & write data to permanent storage.
I have them download & use Node.js to do all their projects so that we aren’t dealing with web browsers. It’s trivial for my students to use IntelliJ to write their code, then run it directly from the toolbar to see their output! Good stuff. For my web dev classes, we go WAYYY more in depth with actual JavaScript on bot the front & back ends and I will cover that in the next posts.
Here are the list of learning resources I use (You don’t have to do every one, but it wouldn’t hurt to at least skim what you don’t go in depth with):
- Code layout & syntax/style - I provide this VIDEO for my students.
- JavaScript Course
- My video on selection logic
- A nice JS Basics course
- An alternative take on learning JS
- Finally, Microsoft’s take on it, which is actually very good! (I personally loathe jQuery, so I can’t recommend those parts at the end.)
- Regular expressions - For your library, I would recommend these two books: Mastering Regular Expressions + Errata & Regular Expressions Cookbook + Errata. THIS is a great tutorial, THIS is a great regex tester, & THIS is a great cheat sheet.
- File I/O demo code. Also notice the input validation.
- Remember to utilize the MDN.
- If you get bored, try Codecademy!
That is a TREMENDOUS amount of learning material to get you up & coding with JavaScript. There is probably 200 hours of stuff on this page. Sorry about that!
⬅️ Go back comments powered by Disqus