Course Syllabus

CS50C: Web Development 3: JavaScript
Section 1828, Fall 2018 Course Syllabus

This syllabus is available in the following formats:

Photo of Instructor Ethan Wilde

Instructor: Ethan Wilde,

Course Description

JavaScript is a cross-platform, object-based scripting language. This course provides a solid foundation in JavaScript and shows students how to create scripts and incorporate them into web pages. Projects include writing Javascript and jQuery programs that manage dynamic content and web page elements such as image slideshows; menus, tabs and panels; form controls and dialogues. Students will also create data-driven web elements using AJAX and API interfaces to web services such as maps and social media.

Recommended Preparation: Course Completion of CS 50.11B OR Course Completion of CS 50A

Prerequisites: Course Completion of CS 50.11B OR Course Completion of CS 50A

Whether you want to become a professional member of a web development team, a game programmer, or a software developer, mastery of the JavaScript programming language is essential to those goals. We will engage in advanced JavaScript language explorations, including use of open source JavaScript libraries such as the jQuery library, the data visualization library D3, and browser-based game programming using the Phaser library. You will become proficient in the creation of interactive experiences using JavaScript and the many freely available open source libraries written in the language.

Student Learning Outcomes

Students will be able to:

  1. Code and deploy basic and intermediate JavaScript, jQuery, and AJAX programs.
  2. Demonstrate and apply the Document Object Model (DOM) and other fundamental Internet technologies accessible through Javascript.

Upon completion of the course, students will be able to:

  1. Analyze and customize Javascript code.
  2. Write JavaScript code that selects and manages document elements, validates form data, creates interactive elements, accesses server data.
  3. Apply appropriate user experience and interactive design concepts to custom websites.
  4. Demonstrate JavaScript scripting skills in a variety of student-designed projects.

Topics and Scope:

  1. Introduction to JavaScript
  2. JavaScript Fundamentals
  3. Putting JavaScript to Work
  4. The Document and Window Objects
  5. Arrays
  6. Working with Numbers and Dates
  7. Working with Strings
  8. Working with Forms
  9. Working with Dynamic Data
  10. Introduction to jQuery
  11. jQuery: Styling Elements
  12. jQuery: Animating Elements
  13. jQuery: Images and Slideshows
  14. jQuery: Navigation
  15. D3: Data Visualization
  16. Phaser: Game Development


  1. Read approximately 25 pages per week
  2. Create 10-14 original JavaScripts and incorporate them into a web-based experience
  3. Download, customize and integrate existing JavaScript libraries into a web-based experience
  4. Download and deploy the jQuery library in a web-based experience
  5. Create a unified website incorporating all class projects and materials
  6. Quizzes, midterm and final exam
  7. Project critiques
  8. Participation in electronic message board discussions (online only classes)

Class Meetings

Fall 2018 Schedule

Online Weeks start on Wednesdays Canvas shell

Live weekly Web conference (optional) 

Week 1: Friday 8/24, 12:00pm - 1:00pm
Weeks 2-17: Thursdays, 12:00pm - 1:00pm

All class materials for each module will be released online in Canvas on Wednesdays throughout the entire semester. A weekly live online meeting will be held on Thursdays, 12:00pm - 1:00pm (except for Week 1, Fri 8/24 instead). Attendance at the live web conferences is optional but highly recommended. Use this link to join:

Instructor Contact

Ethan Wilde


Phone: 707-527-4855

Fall 2018 Office Hours
August 20 – December 14, 2018

Mondays (Online) 11:00am - 2:00pm Online: Email or Skype ethanwilde
Wednesdays 11:00am - 1:00pm Maggini 2937

You can reserve future appointments for my office hours online by visiting

I respond to emails within 48 hours. I never respond on Sundays.

Course Web Site

Students will use the Canvas course web site for assignment instructions, submitting assignments, viewing classmates' work, sharing resources, and viewing grades. The Google Chrome browser is recommended for viewing the Canvas-powered course site. Internet Explorer is not recommended.


Eloquent JavaScript Book Cover

Eloquent JavaScript (3rd)
Marijn Haverbeke
978-1593279509 (ISBN 13)
Free PDF eBook available

Consider getting a copy of these recommended books.

JavaScript & jQuery: The Missing Manual Book Cover

JavaScript & jQuery: The Missing Manual (3rd)
David Sawyer McFarland
1491947071 (ISBN 10)
978-1491947074 (ISBN 13)

Book cover image

JavaScript: The Definitive Guide (6th)
David Flanagan
0596805527 (ISBN 10)
978-0596805524 (ISBN 13)
SRJC Libraries call number: QA76.73.J39 F53 2011
SRJC Libraries physical book available

Consider buying used copies. You can locate and order textbooks online via the SRJC Bookstore.


  • A personal computer, either at home, work or on the Santa Rosa or Petaluma campuses.

Required Software + Services

  • Internet access
  • Web browser
  • Text editor, for Week 1 only, such as:
  • Coding education site
    • CodeCombat free account required for all students.
  • Cloud hosting + development service
    • Cloud9 IDE (Integrated Development Environment) required for all students, starting Week 2, for hosting class assignments. This service provides a complete set of browser-based tools in place of the optional software listed below. Complete the hosting survey to get your free account.
  • Graphics software such as:
    • Adobe Photoshop, part of a Creative Cloud subscription
    • Gimp open source application
    • Pixlr browser-based image editor
  • PDF display software such as:

Optional Software

The additional software listed below is often used for Web development. Our cloud-based IDE – Cloud9 – will provide a text editor and file transfer support without any additional software needed.

  • Additional Web browsers including:
    • Mozilla Firefox
    • Apple Safari (Mac OS only)
    • Microsoft Edge (Windows 10 only)
  • File Transfer Protocol (FTP) software such as:

Important Dates

Day Class Begins: Wednesday, August 22, 2018

Day Class Ends: Friday, December 21, 2018

Last Day to Add without instructor's approval: Sunday, August 26, 2018

Last Day to Drop with refund: Sunday, September 2, 2018

Last Day to Add with instructor's approval: Sunday, September 9, 2018

Last Day to Drop without a 'W' symbol: Sunday, September 9, 2018

Last Day to Opt for Pass/No Pass: Sunday, September 30, 2018

Last Day to Drop with a 'W' symbol: Sunday, November 18, 2018

Dropping the Class

If you decide to discontinue this course, it is your responsibility to officially drop it. A student may be dropped from any class when that student's absences exceed ten percent (10%) of the total hours of class time. It is strongly advised that if you need to miss more than one class/homework deadline in a row that you contact the instructor to avoid being dropped from the class.


For online courses, students who fail to complete the requirements of the first and second class modules will be dropped by the instructor.

Pass‐NoPass (P/NP)

You may take this class P/NP. You must decide before the deadline, and add the option online with TLC or file the P/NP form with Admissions and Records. With a grade of C or better, you will get P.

You must file for the P/NP option by September 30, 2018. Once you decide to go for P/NP, you cannot change back to a letter grade. If you are taking this course as part of a certificate program, you can probably still take the class P/NP. Check with a counselor to be sure.

Instructor Announcements and Q&A Forum

The instructor will post announcements on the “Instructor Announcements” page in Canvas throughout the semester. Canvas notifies students according to their preferred Notification Preferences.

Late Policy

All assignments are due at 11:59pm PST on the Tuesday corresponding to the due date. A late submission will receive a 10% penalty for each week it is late. Submissions more than two weeks late are not accepted without prior written arrangement.


There will be online midterm and final exams. The material comes from the textbook, class lectures and supplemental materials. If any exam is missed, a zero will be recorded as the score, unless you have made prior written arrangements with me. It is your responsibility to take the exams by the due date.

Grading Policy

Click the “Grades” link in Canvas to keep track of your grades. I grade once a week and post grades and comments in the Canvas gradebook.

Grades will be assigned as follows:


90% - 100%

900 points or more


80% - 89%

800 to 899 points


70% - 79%

700 to 799 points


60% - 69%

600 to 699 points


59% or lower

599 points or less

Grading Breakdown


620 points

Projects + Assignments


120 points

Discussions + Attendance


60 points



100 points



100 points

Final Exam


1000 points

1000 points possible

Standards of Conduct

Students who register in SRJC classes are required to abide by the SRJC Student Conduct Standards. Violation of the Standards is basis for referral to the Vice President of Student Services or dismissal from class or from the College. See the Student Code of Conduct page.

Collaborating on or copying of tests or homework in whole or in part will be considered an act of academic dishonesty and result in a grade of 0 for that test or assignment. Students are encouraged to share information and ideas, but not their work. See these links on Plagiarism:
SRJC Writing Center Lessons on avoiding plagiarism
SRJC's statement on Academic Integrity

Special Needs

Every effort is made to conform to accessibility standards for all instructor-created materials. Students should contact their instructor as soon as possible if they find that they cannot access any course materials. Students with disabilities who believe they need accommodations in this class are encouraged to contact Disability Resources by calling (707) 527-4278 or visit online at

Student Health Services

Santa Rosa Junior College offers extensive health services to students. Visit Student Health Services online at or call them at (707) 527-4445.

Course Outline

Topics Assignments
8/22 Week 1 Getting Started Hosting Signup Survey
Assignment 1: Syllabus Quiz
Discussion 1: Check-in Discussion
8/29 Week 2 Play a Game, Learn to Code Assignment 2: CodeCombat
Reading: Eloquent JS, Introduction + Ch. 1
9/5 Week 3 Introduction to JavaScript, Part 1 Assignment 3: Card Sorting
Reading: Eloquent JS, Ch. 2
9/12 Week 4 Introduction to JavaScript, Part 2 Assignment 4: Events
Discussion 2: Events + Objects
Reading: Eloquent JS, Chs. 3 + 4
9/19 Week 5 Exploring the jQuery Library Assignment 5: Quiz App
Reading: Eloquent JS, Chs. 13, 14, 15
9/26 Week 6 Exploring jQuery Plugins, Part 1 Assignment 6: Enhanced User Interfaces
Discussion 3: jQuery + JavaScript Libraries
Reading: Eloquent JS, Ch. 5
10/3 Week 7 Exploring jQuery Plug-ins, Part 2 Assignment 7: Plug-in Promotional Site
Quiz 1
Reading: Eloquent JS, Ch. 6
10/10 Week 8 Exploring the Google Maps API Assignment 8: Class Map
Discussion 4: Concepts of Geolocation
Reading: Eloquent JS, Ch. 8
10/17 Week 9 AJAX: Working with JSON Data Midterm Project: Map-Based Mobile App
Reading: Eloquent JS, Ch. 11
10/24 Week 10 Midterm Review Midterm Exam
Discussion: Midterm Project Presentations
10/31 Week 11 Data Visualization, Part 1 Assignment 9: Basic Data Visualization
Discussion 5: Concepts of Data Visualization
Reading: Eloquent JS, Chs. 17
11/7 Week 12 Data Visualization, Part 2 Assignment 10: Advanced Visualization
Reading: online
11/14 Week 13 Browser-based Game Development Assignment 11: Basic Game
Quiz 2
Discussion 6: Concepts of Game Development
Reading: Eloquent JS, Ch. 10
11/21 Week 14 Building Mobile Apps with Angular.js, Part 1 Assignment 12: Draft Mobile App
Discussion 7: Concepts of Mobile Applications
Reading: online
11/28 Week 15 Building Mobile Apps with Angular.js, Part 2 Assignment 13: Enhanced Mobile App
Reading: online
12/5 Week 16 Server-side JavaScript with Node.js, Part 1 Assignment 14: JSON-Powered Mobile App
Discussion 8: Node.js JavaScript Runtime
Reading: online
12/12 Week 17 Server-side JavaScript with Node.js, Part 2
Final Review
Final Project: Angular.js Mobile Portfolio App
Reading: online
Week 18 No Regular Class Final Exam
Discussion: Final Project Presentations

Note to students: the assignments listed above will become available as modules are released in sequence each week. To view course content, go to Modules.

Course Summary:

Date Details Due