Course Syllabus
CS50C: Web Development 3: JavaScript
Section 5371, Spring 2021 Course Syllabus
This syllabus is available in the following formats:
- Word document: SRJC CS50C 5371 Sp 2021 Syllabus Final v1.docx Download SRJC CS50C 5371 Sp 2021 Syllabus Final v1.docx
- PDF file: SRJC CS50C 5371 Sp 2021 Syllabus Final v1.pdf Download SRJC CS50C 5371 Sp 2021 Syllabus Final v1.pdf
Instructor: Ethan Wilde (he/him/his), ewilde@santarosa.edu
Course Description
This course focuses on JavaScript programming for client-side Web and mobile development. Students learn to create advanced interactive projects including games, data visualizations, generative art, and other browser-based interactive experiences. Students gain experience working with open source JavaScript libraries such as jQuery, the Google Maps API, D3.js and many others. Project-based assignments lead to a comprehensive portfolio of all class projects built as a Web-accessible mobile app.
Recommended Preparation: Eligibility for ENGL 1A or equivalent
Prerequisites: Course Completion or Current Enrollment in CS 50B
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:
- Code and deploy basic and intermediate JavaScript, jQuery, and AJAX programs.
- Demonstrate and apply the Document Object Model (DOM) and other fundamental Internet technologies accessible through JavaScript.
- Integrate HTML5, CSS, and JavaScript to create interactive web content that adhere to current design and accessibility standards.
Upon completion of the course, students will be able to:
- Develop interactive web pages using HTML5 canvas, and media tags.
- Utilize a current industry-standard Framework, HTML5, and CSS to create responsive designs which work well with mobile devices.
- Analyze and customize JavaScript code.
- Write JavaScript, jQuery, and AJAX code that selects and manages document elements, validates form data, creates interactive elements, accesses server data.
- Apply appropriate user experience and interactive design concepts to custom websites.
- Demonstrate HTML5 integration with JavaScript scripting skills in a variety of student-designed projects.
Topics and Scope:
I. HTML5 Application Program Interface (API) Support
A. Canvas overview
B. Adding canvas content
C. Drawing in the canvas environment
D. Charts with canvas
E. Drag-and-drop API overview
F. Offline applications overview
G. Video overview
H. Encoding video
I. Adding video
J. Utilizing a jQuery media player
II. Responsive Web Design
A. Responsive vs. adaptive web design
B. Media queries
C. Introduction to grid-based frameworks
D. Bootstrap
E. Progressive enhancement vs. graceful degradation
III. Accessibility
A. Accessible Rich Internet Applications (ARIA)
B. Accessible forms
C. Accessible tables
D. Testing for accessibility
E. Features and considerations for making accessible web sites
IV. Introduction to JavaScript
A. SCRIPT and NOSCRIPT tags
B. Placing JavaScript on a webpage
C. Using variables
V. JavaScript Fundamentals
A. Using functions
B. Operators
C. Conditionals and loops
VI. Putting JavaScript to Work
A. Events
B. The navigator object
C. Cookies and local data
D. JavaScript timers: SetTimeout and SetInterval
VII. The Document and Window Objects
A. Properties and methods of the DOM (Document Object Model)
B. Uses and best practices
VIII. Arrays
A. JavaScript arrays
B. Properties and methods of arrays
C. Associative arrays
IX. Working with Numbers, Dates, and Strings
A. The math object
B. The number object
C. The date object
X. Working with Forms
A. Accessing the form element
B. The form object
C. Accessibility
D. Validation
E. Using form-based navigation
F. Form widgets in libraries and HTML5 (Hypertext Markup Language 5)
XI. Working with Dynamic Data
A. Asynchronous JavaScript and Extensible Markup Language (AJAX), Extensible Markup Language (XML) and JavaScript Object Notation (JSON)
B. Dynamic data using jQuery
XII. Introduction to jQuery
A. What is jQuery
B. Downloading data using jQuery
XIII. jQuery: Styling Elements
A. Selecting elements
B. Reading and setting Cascading Style Sheets (CSS) properties
C. Classes
D. Adding and removing elements
E. Modifying content
XIV. jQuery: Animating Elements
A. Easing
B. Animated navigation
C. Scrolling
D. Resizing
XV. jQuery: Images and Slideshows
A. Simple custom lightbox
B. jCrop
C. Crossfading
XVI. jQuery: Navigation
A. Collapsible menus
B. Accordions
C. Tabs
D. Panels
Assignments:
- Textbook reading (25 - 60 pages per week)
- Critique and analyze existing websites that use client-side technology
- Create original JavaScripts and incorporate them into a website (6 - 8)
- Download, customize and integrate existing JavaScript components into a website (3 - 4)
- Download and deploy the jQuery library in webpage features (2 - 3)
- Create a unified website incorporating all class projects and materials
- Exams
Class Meetings
Spring 2021 Schedule
Class Delivery | Day and Time | Platform |
---|---|---|
Online Meetings | Weeks start on Tuesdays | Canvas shell |
Live weekly Web conference (optional) |
Tuesdays, 3:30pm - 4:30pm | Zoom |
All class materials for each module will be released online in Canvas on Tuesdays throughout the entire semester. A weekly live online meeting will be held on Tuesdays, 3:30pm - 4:30pm. Attendance at the live web conferences is optional but highly recommended. Use this link to join: https://santarosa-edu.zoom.us/j/406692699 Links to an external site.. To view any weekly lecture's recorded screencast, visit the Screencast page for any week in the Modules section.
Because there are no classes on the first Tuesday in the Spring 2021 semester, due to professional development activities, the first live Web conference will take place on Thursday, January 21, 3:30pm - 4:30pm.
Instructor Contact
Ethan Wilde
Email: ewilde@santarosa.edu
Phone: 707-527-4855
Spring 2021 Office Hours
January 25 – May 17, 2021
Day | Time | Location |
---|---|---|
Mondays (online) | 12:00pm - 6:00pm | Online: Email ewilde@santarosa.edu or Skype ethanwilde Links to an external site. |
» Reserve a future office hour appointment Links to an external site.
I typically respond to emails within 48 hours, weekends excepted. 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.
Required Textbook
Eloquent JavaScript (3rd)
Marijn Haverbeke
978-1593279509 (ISBN 13)
Free PDF eBook available
Links to an external site.
Recommended Textbooks
Consider getting a copy of these recommended books.
JavaScript & jQuery: The Missing Manual (3rd)
David Sawyer McFarland
1491947071 (ISBN 10)
978-1491947074 (ISBN 13)
JavaScript in 24 Hours, Sams Teach Yourself (7th)
Phil Ballard
0672338092 (ISBN 10)
978-0672338090 (ISBN 13)
The Modern JavaScript Tutorial (free online)
Ilya Kantor
https://javascript.info/
Links to an external site.
Consider buying used copies. You can locate and order textbooks online via the SRJC Bookstore.
Equipment
- A personal computer, either at home, work or on the Santa Rosa or Petaluma campuses.
Required Software + Services
- Internet access
-
Web browsers including:
- Google Chrome Links to an external site. recommended and typically used in instructor demos
- Mozilla Firefox Links to an external site. recommended
-
Coding education site
- CodeCombat free account required for all students.
-
Cloud hosting + development service
- Repl.it Links to an external site. IDE (Integrated Development Environment) required for all students, starting Week 2, for hosting class assignments during the term. Repl.it will provide a text editor and file transfer support without any additional software needed. Complete the hosting survey to get your free account.
-
Graphics software such as:
- Adobe Photoshop, part of a Creative Cloud Links to an external site. subscription
- Gimp Links to an external site. open source application
- Pixlr Links to an external site. browser-based image editor
- Diagrams.net Links to an external site. browser-based drawing app
- PDF display software such as:
Optional Software
The additional software listed below is often used for Web development. Our cloud-based IDE – Repl.it – will provide a text editor and file transfer support without any additional software needed.
-
Code editor such as:
- Brackets Links to an external site. (Windows, Mac OS, free license)
- Microsoft Visual Studio Code Links to an external site. (Windows, Mac OS, free license)
- BBEdit Links to an external site. (Mac OS only)
- Sublime Text Links to an external site. (Windows, Mac OS, Linux)
-
File Transfer Protocol (FTP) software such as:
- CyberDuck Links to an external site. (Mac OS and Windows, free license)
- Fetch Links to an external site. (Max OS only)
- WinSCP Links to an external site. (Windows only)
- Additional Web browsers including:
- Apple Safari (Mac OS only)
- Microsoft Edge (Windows 10 only)
Important Dates
Day Class Begins: Tuesday, January 19, 2021*
Day Class Ends: Friday, May 28, 2021
Last Day to Add without instructor's approval: Tuesday, January 26, 2021
Last Day to Drop with refund: Sunday, January 31, 2021
Last Day to Add with instructor's approval: Sunday, February 7, 2021
Last Day to Drop without a 'W' symbol: Sunday, February 7, 2021
Last Day to Opt for Pass/No Pass: Sunday, February 28, 2021
Last Day to Drop with a 'W' symbol: Sunday, April 25, 2021
* Note that there are no class meetings on the first Tuesday of the Spring 2021 semester, 1/19/2021, due to professional development activities. As a result, our first live class meeting will take place on Thursday, 1/21/2021.
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.
Attendance
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 within your student portal 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 February 28, 2021. 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
The instructor will post announcements on the “Announcements” page in Canvas throughout the semester. Canvas notifies students according to their preferred Notification Preferences.
Late Policy
Please make a plan before the course starts to allow yourself the necessary time each week to complete the required reading, watching, online discussion posting, and assignments. The official Course Outline of Record for this three-unit semester-length course stipulates that each student is expected to complete 157.5 hours of learning for the class. This works out to 9 hours per week for each of the seventeen weeks of regular instruction along with 4.5 hours for Finals Week. If you plan accordingly, you can avoid submitting assignments late.
All assignments are due at 11:59pm Pacific time on the Monday 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.
Exams
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:
Letter Grade |
Percentage |
Points Total |
---|---|---|
A |
90% - 100% |
900 points or more |
B |
80% - 89% |
800 to 899 points |
C |
70% - 79% |
700 to 799 points |
D |
60% - 69% |
600 to 699 points |
F |
59% or lower |
599 points or less |
If taking Pass/No Pass you need at least 70% of the total class points and to complete the midterm exam and the final exam to pass the class.
Grading Breakdown
Percent |
Points |
Grading Category |
---|---|---|
62% |
620 points |
Projects + Assignments |
12% |
120 points |
Discussions + Attendance |
6% |
60 points |
Quizzes |
10% |
100 points |
Midterm |
10% |
100 points |
Final Exam |
100% |
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, except for assignments that allow collaboration. Students are encouraged to share information and ideas, but not their work. See these links on Plagiarism:
SRJC Writing Center Lessons on Avoiding Plagiarism
Links to an external site.
SRJC's Statement on Academic Integrity
I expect each student to maintain high standards of civility and respect when communicating with each other. The following rules of netiquette should be observed in all class discussions and communications:
- Be kind and respectful to others
- Use full sentences
- Avoid jargon and acronyms
- Use language that supports others
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 drd.santarosa.edu.
Student Health Services
Santa Rosa Junior College offers extensive health services to students. Visit Student Health Services online at shs.santarosa.edu or call them at (707) 527-4445.
Course Outline
Start Date |
Canvas Module |
Topics | Assignments |
---|---|---|---|
1/19 (1/21) |
Week 1 | Getting Started |
|
1/26 | Week 2 | Play a Game, Learn to Code |
|
2/2 | Week 3 | Introduction to JavaScript, Part 1 |
|
2/9 | Week 4 | Introduction to JavaScript, Part 2 |
|
2/16 | Week 5 | Exploring the jQuery Library |
|
2/23 | Week 6 | Exploring jQuery Plugins, Part 1 |
|
3/2 | Week 7 | Exploring jQuery Plug-ins, Part 2 |
|
3/9 | Week 8 | Exploring Geography Visualization APIs |
|
3/16 | Week 9 | AJAX: Working with JSON Data |
|
3/23 | No Class | Spring Break | |
3/30 | Week 10 | Midterm Review |
|
4/6 | Week 11 | Data Visualization, Part 1 |
|
4/13 | Week 12 | Data Visualization, Part 2 |
|
4/20 | Week 13 | Browser-based Game Development, Part 1 |
|
4/27 | Week 14 | Browser-based Game Development, Part 2 |
|
5/4 | Week 15 | Building Mobile Apps with Vue.js, Part 1 |
|
5/11 | Week 16 | Building Mobile Apps with Vue.js, Part 2 |
|
5/18 | Week 17 | Server-side JavaScript with Node.js Final Review |
|
5/24 Mon - 5/28 Fri |
Week 18 | No Regular Class (Exam online, no regular class meeting) |
|
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.
All of the original material found on this online course website is the property of the instructor, Ethan Wilde. My lectures and course materials, including slide presentations, online materials, tests, outlines, and similar materials, are protected by U.S. copyright law and by College policy. I am the exclusive owner of the copyright in those materials I create. You may take notes and make copies of course materials for your own use. You may also share those materials with another student who is registered and enrolled in this course. You may not reproduce, distribute or display (post/upload) lecture notes or recordings or course materials in any other way — whether or not a fee is charged — without my express written consent. You also may not allow others to do so.
© 2021 Ethan Wilde.
Course Summary:
Date | Details | Due |
---|---|---|
Thu Jan 21, 2021 | Calendar Event CS50C Weekly Lecture 1 | 3:30pm to 4:30pm |
Mon Jan 25, 2021 | Quiz Week 1: Assignment 1: Syllabus Quiz | due by 11:59pm |
Discussion Topic Week 1: Check-In Discussion | due by 11:59pm | |
Tue Jan 26, 2021 | Calendar Event CS50C Weekly Lecture 2 | 3:30pm to 4:30pm |
Mon Feb 1, 2021 | Quiz Weeks 1-2: Assignment 2: CodeCombat + Basic JavaScript | due by 11:59pm |
Tue Feb 2, 2021 | Calendar Event CS50C Weekly Lecture 3 | 3:30pm to 4:30pm |
Mon Feb 8, 2021 | Quiz Week 3: Assignment 3: More JavaScript | due by 11:59pm |
Tue Feb 9, 2021 | Calendar Event CS50C Weekly Lecture 4 | 3:30pm to 4:30pm |
Mon Feb 15, 2021 | Quiz Week 4: Assignment 4: Events + Objects | due by 11:59pm |
Discussion Topic Weeks 4-5: Discussion 2: Events + Objects | due by 11:59pm | |
Tue Feb 16, 2021 | Calendar Event CS50C Weekly Lecture 5 | 3:30pm to 4:30pm |
Mon Feb 22, 2021 | Quiz Week 5: Assignment 5: Shared Libraries | due by 11:59pm |
Tue Feb 23, 2021 | Calendar Event CS50C Weekly Lecture 6 | 3:30pm to 4:30pm |
Mon Mar 1, 2021 | Calendar Event CS50C Weekly Lecture 7 | 3:30pm to 4:30pm |
Discussion Topic Weeks 6-7: Discussion 3: jQuery + JavaScript Libraries | due by 11:59pm | |
Tue Mar 2, 2021 | Quiz Week 6: Assignment 6: Enhanced User Interfaces | due by 11:59pm |
Mon Mar 8, 2021 | Quiz Week 7: Assignment 7: jQuery Plugin Promotional Site | due by 11:59pm |
Quiz Week 7: Quiz 1 | due by 11:59pm | |
Wed Mar 10, 2021 | Calendar Event CS50C Weekly Lecture 8 | 2pm to 3pm |
Tue Mar 16, 2021 | Calendar Event CS50C Weekly Lecture 9 | 3:30pm to 4:30pm |
Quiz Week 8: Assignment 8: Class Map | due by 11:59pm | |
Discussion Topic Weeks 8-9: Discussion 4: Concepts of Geolocation | due by 11:59pm | |
Mon Mar 29, 2021 | Quiz Week 9: Midterm Project: Map-Based Mobile App | due by 11:59pm |
Tue Mar 30, 2021 | Calendar Event CS50C Weekly Lecture 10 | 3:30pm to 4:30pm |
Mon Apr 5, 2021 | Quiz Week 10: Midterm Exam | due by 11:59pm |
Discussion Topic Week 10: Midterm Project Presentations | due by 11:59pm | |
Tue Apr 6, 2021 | Calendar Event CS50C Weekly Lecture 11 | 3:30pm to 4:30pm |
Mon Apr 12, 2021 | Discussion Topic Weeks 11-12: Discussion 5: Concepts of Data Visualization | due by 11:59pm |
Quiz Week 11: Assignment 9: Basic Data Visualization | due by 11:59pm | |
Tue Apr 13, 2021 | Calendar Event CS50C Weekly Lecture 12 | 3:30pm to 4:30pm |
Mon Apr 19, 2021 | Quiz Week 12: Assignment 10: Advanced Visualization | due by 11:59pm |
Tue Apr 20, 2021 | Calendar Event CS50C Weekly Lecture 13 | 3:30pm to 4:30pm |
Mon Apr 26, 2021 | Quiz Week 13: Assignment 11: Basic Game | due by 11:59pm |
Discussion Topic Weeks 13-14: Discussion 6: Concepts of Game Development | due by 11:59pm | |
Tue Apr 27, 2021 | Calendar Event CS50C Weekly Lecture 14 | 3:30pm to 4:30pm |
Mon May 3, 2021 | Quiz Week 14: Assignment 12: Your Game | due by 11:59pm |
Tue May 4, 2021 | Calendar Event CS50C Weekly Lecture 15 | 3:30pm to 4:30pm |
Mon May 10, 2021 | Quiz Week 15: Assignment 13: Basic Mobile App | due by 11:59pm |
Discussion Topic Weeks 15-16: Discussion 7: Concepts of Mobile Applications | due by 11:59pm | |
Quiz Week 15: Quiz 2 | due by 11:59pm | |
Tue May 11, 2021 | Calendar Event CS50C Weekly Lecture 16 | 3:30pm to 4:30pm |
Mon May 17, 2021 | Quiz Week 16: Assignment 14: Your Mobile App | due by 11:59pm |
Tue May 18, 2021 | Calendar Event CS50C Weekly Lecture 17 | 3:30pm to 4:30pm |
Mon May 24, 2021 | Discussion Topic Weeks 17-18: Discussion 8: Node.js JavaScript Runtime | due by 11:59pm |
Quiz Week 17: Final Project | due by 11:59pm | |
Fri May 28, 2021 | Discussion Topic JavaScript Development Class-Sourced Resource Wiki | due by 11:59pm |
Discussion Topic Week 18: Discussion: Final Project Presentations | due by 11:59pm | |
Quiz Week 18: Final Exam | due by 11:59pm | |
Assignment Roll Call Attendance |