Table of Contents

1.1 Web history
1.2 IP addresses, domain names, and URLs
1.3 HTTP
1.4 Web trends
1.5 Introduction to HTML
1.6 Introduction to CSS
1.7 Introduction to JavaScript
1.8 Full-stack development
1.9 Front-end tools

2.1 HTML document structure
2.2 HTML sandbox
2.3 Basic HTML elements
2.4 Comments
2.5 Images
2.6 Links
2.7 Lists
2.8 Tables
2.9 Special characters
2.10 Example: Band webpage

3.1 HTML containers
3.2 Forms
3.3 Common form widgets
3.4 Additional form widgets
3.5 Audio and video
3.6 < script > and < style >
3.7 HTML developer guidelines
3.8 Example: Restaurant Reviews

4.1 Using CSS in HTML
4.2 CSS sandbox
4.3 Basic selectors
4.4 Advanced selectors
4.5 Common properties
4.6 Font and text properties
4.7 Box model
4.8 Example: Styled band webpage

5.1 Flexbox
5.2 Grid layout
5.3 Positioning elements
5.4 Special effects
5.5 Animation
5.6 Styling forms
5.7 Sass
5.8 Example: Styled Restaurant Reviews

6.1 Syntax and variables
6.2 JavaScript sandbox
6.3 Arithmetic
6.4 Conditionals
6.5 More conditionals
6.6 Loops
6.7 Functions
6.8 Scope and the global object
6.9 Arrays
6.10 Objects
6.11 Maps
6.12 String object
6.13 Date object
6.14 Math object
6.15 Exception handling

7.1 Using JavaScript with HTML
7.2 JavaScript in the browser sandbox
7.3 Document Object Model (DOM)
7.4 More DOM modification
7.5 Event-driven programming
7.6 Timers
7.7 Modifying CSS with JavaScript
7.8 Form validation
7.9 JavaScript Object Notation (JSON)
7.10 XMLHttpRequest (Ajax)
7.11 Using third-party web APIs (JavaScript)
7.12 Browser differences: JavaScript
7.13 Example: Lights Out game
7.14 Example: Weather Comparison (XMLHttpRequest)

8.1 Regular expressions
8.2 Classes
8.3 Classes (ES6)
8.4 Classes (ES13)
8.5 Inner functions, outer functions, and function scope
8.6 Closures
8.7 Modules
8.8 Strict mode
8.9 Web storage
8.10 Canvas drawing
8.11 Canvas transformations and animation
8.12 WebSockets
8.13 Promises
8.14 async and await
8.15 Fetch API
8.16 Example: Lights Out game with canvas
8.17 Example: Weather Comparison (fetch)

9.1 Mobile websites and browsers
9.2 Mobile development tools
9.3 Viewport
9.4 Media queries
9.5 Responsive images
9.6 Bootstrap
9.7 Example: Responsive band webpage

10.1 Introduction to accessibility
10.2 Accessibility tools
10.3 Page structure
10.4 WAI-ARIA
10.5 Colors
10.6 Images (a11y)
10.7 Links (a11y)
10.8 Text
10.9 Forms (a11y)

11.1 Getting started with Node.js
11.2 Node.js sandbox
11.3 Express
11.4 Express request data
11.5 Embedded JavaScript
11.6 Pug

12.1 Relational databases and SQL (Node)
12.2 MySQL
12.3 MySQL2
12.4 MongoDB
12.5 Mongoose
12.6 VS Code
12.7 RESTful web APIs: Part 1 (Node)
12.8 RESTful web APIs: Part 2 (Node)
12.9 Using RESTful web APIs with Fetch
12.10 Third-party web APIs (Node)
12.11 Token-based user authentication (Node)
12.12 Password hashing (Node)

13.1 Getting started with React
13.2 React sandbox
13.3 JSX
13.4 Components
13.5 Event handling
13.6 State
13.7 Conditional rendering
13.8 Lists (React)
13.9 Forms (React)
13.10 Example: Todo List
13.11 Router
13.12 Styling
13.13 React Bootstrap
13.14 Fetching data
13.15 Example: Message Board back-end
13.16 Example: Message Board front-end (Part 1)
13.17 Example: Message Board front-end (Part 2)

14.1 Getting started with PHP
14.2 PHP sandbox
14.3 Arithmetic and comparisons (PHP)
14.4 Conditionals (PHP)
14.5 Loops (PHP)
14.6 Arrays (PHP)
14.7 Functions (PHP)
14.8 Includes (PHP)
14.9 Classes and objects (PHP)
14.10 String, date/time, and math functions (PHP)
14.11 Submitting forms (PHP)
14.12 Form validation and sanitation (PHP)

15.1 Regular expressions (PHP)
15.2 Error handling (PHP)
15.3 File handling (PHP)
15.4 Uploading files (PHP)
15.5 Cookies and sessions (PHP)
15.6 Relational databases and SQL (PHP)
15.7 MySQL (PHP)
15.8 MySQLi (PHP)
15.9 PHP Data Objects (PHP)
15.10 User authentication principles (PHP)
15.11 Implementing user authentication (PHP)
15.12 Using third-party web APIs (PHP)

16.1 Relational databases
16.2 Structured Query Language (SQL)
16.3 SQL sandbox
16.4 Creating, altering, and deleting tables
16.5 Inserting rows
16.6 Selecting rows
16.7 SQL functions
16.8 Joining tables
16.9 Updating and deleting rows

17.1 Getting started with jQuery
17.2 Selectors (jQuery)
17.3 Events (jQuery)
17.4 Styles and animation (jQuery)
17.5 DOM manipulation (jQuery)
17.6 Ajax (jQuery)
17.7 Using third-party web APIs (jQuery)
17.8 Using RESTful web APIs with jQuery
17.9 Plugins (jQuery)
17.10 Example: Weather Comparison (jQuery)
17.11 MySQL module (Node)

Tips for Teaching your Web Programming Course

Web programming is one of my favorite courses to teach. Having taught web programming to computer science (CS) undergraduates for more than 20 years, I have suggestions for instructors who are new to teaching web programming or wondering what to teach in their web courses.

Teach full-stack development with this fully interactive introduction to key web programming concepts

Web Programming introduces full-stack development of web applications using the latest web standards.

  • Covers client-side technologies such as HTML, CSS, JavaScript, React, and server-side technologies, including Node.js, PHP, relational and NoSQL databases
  • Provides interactive HTML, CSS, and JavaScript practice problems with built-in auto-grading that run right in the zyBook, giving students instant feedback and saving instructors time
  • Provides the ability to run Node, React, and PHP code directly within the zyBook
  • Includes a zyLab IDE that simplifies how students write and submit their lab solutions
  • Adopters have access to a test bank with more than 500 multiple-choice questions

Lead author Professor Frank McCown demonstrates the zyLabs interface:

What is a zyBook?


Web Programming is an interactive learning solution that helps students visualize concepts, enabling them to learn more effectively than with a traditional textbook. Check out our research.

zyBooks benefits students and instructors:

  • Instructor benefits
  • Customize your course by reorganizing existing content or adding your own
  • Continuous publication model updates your course with the latest content and technologies
  • Robust reporting gives you insight into students’ progress, reading and participation
  • Save time with auto-graded labs and challenge activities that seamlessly integrate with your LMS gradebook
  • Student benefits
  • Learning questions and other content serve as an interactive form of reading
  • Instant feedback on labs and homework
  • Concepts come to life through extensive animations embedded into the interactive content
  • Save chapters as PDFs to reference the material at any time

See the React tools:

Author

Frank McCown, PhD

Professor of Computer Science, Harding University

Instructors: Interested in evaluating this zyBook for your class?

Check out these related zyBooks