Overview
Web Essentials: Modern JavaScript is a hands-on web development course geared for software developers who need to understand what JavaScript is and how to use it with today’s systems and architectures. You will learn javascript to expand your knowledge and skills in architecting and developing sophisticated web interfaces.
Learn javascript and get a balanced mixture of theory and practical labs designed to take you through the fundamentals of JavaScript to the use of tools and libraries, and ease the development of advanced web applications. You will hit the ground running, applying JavaScript to projects at both an architectural as well as a line-by-line coding level. You will leave this course armed with the required skills to design, implement, and deploy robust, flexible, and safe JavaScript-based applications to a foundational level.
This class is “technology-centric”, designed to train you in essential development skills, coupling the most current, effective techniques with the soundest industry practices. This course is about 50% hands-on lab and 50% lecture, with extensive programming exercises designed to reinforce fundamental skills and concepts learned in the lessons.
In this Course, You Will Learn Javascript Fundamentals and How to:
- Use Javascript within the context of web applications
- Work with the different technologies that are the foundation for web applications
- Work with the fundamental aspects of JavaScript in terms of web applications, security, tools, and frameworks
- Effectively work with the newest advances in JavaScript such as ES6 and TypeScript
- Develop code using conventions and optimal constructs for performance
Course Outline
Part 1: HTML
Lesson: HTML (Optional)
- Define HTML and review its history
- Look at XHTML and its relationship to HTML
- Identify HTML limitations and improvements
- Exercise: Working with HTML
Lesson: HTML5
- HTML5 Overview
- HTML5 Semantic Structure
- HTML5 Forms
- HTML5 Media Delivery
Exercise: Writing a Valid HTML5 Document
Exercise: Writing HTML5 Forms
Part 2: CSS
Lesson: CSS (Optional)
- Learn the basics of CSS
- Meaning of cascading in CSS
- Declaring CSS within your HTML page
- Creating styles in an external CSS file
- Control how to display and position HTML elements
- Overriding standard tag behavior
- Adding new classes
- Using custom classes in your page
- Exercise: Working with CSS
Lesson: CSS3 Overview
- What is new in CSS3
- The Advantages of CSS3
- Browser Support for CSS3
Exercise: Working with CSS3
Part 3: JavaScript
Lesson: JavaScript Basics
- JavaScript Defined
- Variables and Operators
- Flow Control and Conditionals
Exercise: JavaScript Basics
Lesson: Debugging Tools
- Using the strict mode and setting breakpoints
- Browser debugging tools
- Monitoring resource usage and performance
- Emulating devices Exceptions in JavaScript
Exercise: JavaScript Debugging
Lesson: JavaScript Functions
- Functions in JavaScript
- Invoking Functions
- Function Constructor
- Function Scope and Closures
Lesson: JavaScript Arrays, Math and Date
- JavaScript Literals
- JavaScript Arrays
- Working with Numbers and Dates
Exercise: JavaScript Built-in Objects
Lesson: JavaScript Event Handling and the DOM
- Events and Event Handling
- HTML Document Object Model
- Accessing the DOM
- Dynamically Working with the DOM
- DOM Challenges
Exercise: Using Events and the DOM
Lesson: Object-Oriented JavaScript
- JavaScript “Objects” and “Classes”
- Constructors and Prototypes
- Prototypes
- Extending Classes with Prototype
- Reusable, Flexible Classes
Exercise: Working with Classes
Part 4: Advanced JavaScript Topics
Lesson: ES6: The Next Step
- ES6 Defined
- ES6 Default and Rest Parameters
- IIFE and Closures
- ES6 Importing/Exporting Modules
- Arrays, ES6 Maps, and ES6 Sets
- Working Arrays with ES6
- Working Strings with ES6 Strings
- ES6 Constructs and Inheritance
- ES6: Getters and Setters
Exercise: Working with ES6
Lesson: TypeScript
- Strong Data Typing
- Compiling TypeScript to JavaScript
- TypeScript Datatypes
- TypeScript Classes and Interfaces
Lesson: Introduction to JSON and Ajax
- JavaScript Object Notation
- AJAX: Load Once and Change Data
- XMLRequestObject is at the Center
- Calling the Service
- The Callback
Exercise: Implementing JSON
Lesson: JavaScript Best Practices
- Code Conventions for the Lifecycle
- Resolving Shared Resources
- Constructs to Use
- Constructs to Avoid
- Memory Considerations
Lesson: JavaScript Scheduling, Execution, and Security
- Timers and Scheduling
- Execution Contexts
- Same Origin Policy and JavaScript
- Security Considerations
Lesson: HTML5 JavaScript API
- Cross-Domain Messaging
- Working with Web Storage
- Offline with Application Cache
- Geolocation: What, Why, and How
Exercise: Using the Web Storage API
Exercise: Using the ApplicationCache API
Part 5: Working with XML (Optional)
Lesson: XML DOM Mechanics
- HTML vs XML DOM
- Building an XML DOM
- Integrating XML into HTML
- XML Response Processing
Exercise: Loading XML Data into an HTML Page
Lesson: XSLT Applied
- XSLT in the Browser
- XSLT in Specific Browsers
- Sarissa Assistance
- XSLT Pluses and Minuses
Exercise: XSLT Transformations with Sarissa
This course is available on our public schedule via Live Virtual Classroom:
Contact us here.