CMPE 280 Web UI Design and Development

Similar documents
CMPE 280 Web UI Design and Development

CMPE 152 Compiler Design

CS/SE 153 Concepts of Compiler Design

CMPE 152 Compiler Design

CMPE 152 Compiler Design

CMPE/SE 135 Object-Oriented Analysis and Design

CS/SE 153 Concepts of Compiler Design

CMPE 180A Data Structures and Algorithms in C++

San José State University Department of Computer Science CS-174, Server-side Web Programming, Section 2, Spring 2018

San José State University College of Science/Department of Computer Science CS 152, Programming Language Paradigms, Section 03/04, Fall, 2018

San Jose State University College of Science Department of Computer Science CS151, Object-Oriented Design, Sections 1,2 and 3, Spring 2017

San José State University Department of Computer Science CS166, Information Security, Section 1, Fall, 2018

San Jose State University College of Science Department of Computer Science CS185C, Introduction to NoSQL databases, Spring 2017

San Jose State University - Department of Computer Science

San Jose State University College of Science Department of Computer Science CS185C, NoSQL Database Systems, Section 1, Spring 2018

San Jose State University College of Science Department of Computer Science CS151, Object-Oriented Design, Sections 1, 2, and 3, Spring 2018

San José State University Computer Science Department CS49J, Section 3, Programming in Java, Fall 2015

San José State University Department of Computer Science CS-144, Advanced C++ Programming, Section 1, Fall 2017

San José State University Department of Computer Science CS151, Section 04 Object Oriented Design Spring 2018

San José State University College of Science/Department of Computer Science CS152, Programming Paradigms, Sections 1 & 2 Spring Semester, 2018

CSCI 6312 Advanced Internet Programming

San José State University Department of Computer Science CS049J, Programming in Java, Section 2, Fall, 2016

San José State University Department of Computer Science CS 166 / SE 166, Information Security, Section 4, spring, 2017

San José State University Department of Computer Science CS151, Object Oriented Design, Section 04, Fall, 2016 (42968)

Course and Contact Information. Course Description. Course Objectives

San José State University College of Science / Department of Computer Science Introduction to Database Management Systems, CS157A-3-4, Fall 2017

San José State University College of Science/Department of Computer Science CS152, Programming Paradigms, Sections 1 & 2, Fall Semester, 2017

Course and Contact Information. Course Description. Course Objectives

San José State University College of Science/Department of Computer Science CS152, Programming Paradigms, Sections 3 & 4, Fall Semester, 2016

AE Computer Programming for Aerospace Engineers

San José State University Computer Science Department CS157A: Introduction to Database Management Systems Sections 5 and 6, Fall 2015

CSC 443: Web Programming

San José State University Computer Science CS 122 Advanced Python Programming Spring 2018

DIG 3110 Web Design & Interactive Media

Demonstrate web development using appropriate HTML markup tags, elements and attributes.

Internet Web Technologies ITP 104 (2 Units)

INFSCI 1017 Implementation of Information Systems Spring 2017

CIS 408 Internet Computing (3-0-3)

San Jose State University College of Science Department of Computer Science CS151, Object-Oriented Design, Sections 1 and 2, Spring 2016

San José State University Department of Computer Science CS158B, Computer Network Management, Section 1, Fall 2016

COURSE SYLLABUS FOR. COMP-297 Web Page Design: Adobe Dreamweaver

CSCI 201L Syllabus Principles of Software Development Spring 2018

Advanced Client-Side Web Programming CSCI 491/595 Syllabus Fall 2018

PELLISSIPPI STATE TECHNICAL COMMUNITY COLLEGE MASTER SYLLABUS CIW JAVASCRIPT FUNDAMENTALS CERTIFICATION WEB 2391

Web II CE 2413C 01 CE 2414N 01 Spring 2013

Basic Web Application Development Spring credit hour Student Taught (Satisfactory/Unsatisfactory)

COSC 115A: Introduction to Web Authoring Fall 2014

Developing Web Applications and Services Course Syllabus Fall 2015

CPS352 Database Systems Syllabus Fall 2012

INF 315E Introduction to Databases School of Information Fall 2015

ISM 324: Information Systems Security Spring 2014

Murach's HTML and CSS3 3 rd Edition By Boehm, Anne Fresno, Calif Publisher: Mike Murach & Associates, 2015 ISBN-13:

University of Maryland at College Park Department of Geographical Sciences GEOG 477/ GEOG777: Mobile GIS Development

SUBJECT OUTLINE DETAILS

CIS 3308 Web Application Programming Syllabus

Programming in HTML5 with JavaScript and CSS3

B. Subject-specific skills B1. Problem solving skills: Supply the student with the ability to solve different problems related to the topics

INST Database Design and Modeling - Section 0101 Spring Tentative Syllabus

,

Web Development: Client Side

CPS352 - DATABASE SYSTEMS. Professor: Russell C. Bjork Spring semester, Office: KOSC 242 x4377

PUBLISHING 1231 Intermediate New Media Publishing (FLASH) Instructor: Mak (Mahmoud) Abdel-Hai Office: A248 Phone: 604-3

Information Brochure Information Brochure. An ISO 9001:2015 Institute. ADMEC Multimedia Institute. Web Master Plus. Designing Development Promotion

Accounting & MIS 3610

Murach's HTML and CSS3 3 rd Edition By Boehm, Anne Fresno, Calif Publisher: Mike Murach & Associates, 2015 ISBN-13:

Kingdom of Saudi Arabia Ministry of Higher Education College of Computer & Information Sciences Majmaah University. Course Profile

Web Programming Spring 2010

Web Client Side Programming

Course 20480: Programming in HTML5 with JavaScript and CSS3

COURSE 20480B: PROGRAMMING IN HTML5 WITH JAVASCRIPT AND CSS3

Our trainings can be delivered as an Onsite Classroom Training or as an Instructor-Led Live Online Training(ILT).

CS 241 Data Organization using C

CS 3270 Mobile Development for Android Syllabus

Syllabus Revised 01/03/2018

Programming in HTML5 with JavaScript and CSS3

COWLEY COLLEGE & Area Vocational Technical School

Course Syllabus Internal Control And Auditing ACNT 2331

Computer Science Technology Department

Syllabus Class schedule Section 1: Tuesdays 9:00 11:50 Section 2: Tuesdays 1:00 3:50

MCOM 6336 Digital Media Spring 2014

Rochester Institute of Technology Golisano College of Computing and Information Sciences Department of Information Sciences and Technologies

Dr. Angela Guercio Dr. Natalia Dragan. Spring 2011

Spring 2018 El Camino College E. Ambrosio. Course Syllabus

Microsoft Programming in HTML5 with JavaScript and CSS3

The University of Jordan

THE UNIVERSITY OF TEXAS AT AUSTIN MIS373 e-discovery and Digital Forensics SPRING 2015 Unique#: (03665) VERSION: 2_011718

20486-Developing ASP.NET MVC 4 Web Applications

VIS II: Design Communication Graphic Design Basics, Photoshop and InDesign Spring 2018

Advanced Topics in Database Systems Spring 2016

KOMAR UNIVERSITY OF SCIENCE AND TECHNOLOGY (KUST)

EEL 4930/5934 Advanced Systems Programming - Spring 2017

IT 341 Fall 2017 Syllabus. Department of Information Sciences and Technology Volgenau School of Engineering George Mason University

Cleveland State University Department of Electrical and Computer Engineering. CIS 408: Internet Computing

INTERFACE FOUNDATIONS OF WEB DEVELOPMENT

Section 1 (10724): Tuesday & Thursday, 2:00pm- 3:15pm, Harrison Hall, Lab 0101

San José State University Department of Computer Science CS-144, Advanced C++ Programming, Section 1, Spring 2018

Art 645 Introduction to Web Site Design Los Angeles City College

Syllabus -- CIS Computer Maintenance / A+ Certification

Computer Science Technology Department

Geography 3300: Transportation Security

Transcription:

San José State University Department of Computer Engineering CMPE 280 Web UI Design and Development Section 2 Spring 2019 Course and Contact Information Instructor: Ron Mak Office Location: ENG 250 Email: ron.mak@sjsu.edu Website: http://www.cs.sjsu.edu/~mak/ Office Hours: TuTh 3:00-4:00 PM Class Days/Time: TuTh 10:30-11:45 AM Classroom: Dudley Moorhead Hall DMH 227 Prerequisites: Classified graduate standing or instructor consent. Computer Engineering and Software Engineering majors only. Course Format This course will be taught primarily via classroom presentations. Faculty Web Page and Canvas Course materials, syllabus, assignments, grading criteria, exams, and other information will be posted at my faculty website at http://www.cs.sjsu.edu/~mak and on the Canvas Learning Management System course login website at http://sjsu.instructure.com. You are responsible for regularly checking these websites to learn of any updates. You can find Canvas video tutorials and documentations at http://ges.sjsu.edu/canvas-students Course Catalog Description Web User-interface (UI) design and development with contemporary web standards. Understand interaction and interface design principles and processes for rich web applications, mobile web, web graphics, web design fundamentals, tools, interaction using client-side scripting and server-side frameworks. Academic Integrity Major exams in this class may be video recorded to ensure academic integrity. The recordings will only be viewed if there is an issue to be addressed. Under no circumstances will the recordings be publicly released. CMPE 280 Web UI Design and Development, Spring 2019, Ron Mak Page 1 of 8

Course Goals This section of the course will concentrate on current industry practices of UI design for web applications and on the tools and techniques to develop these applications. The first half of the semester will introduce the practices, tools, and technologies. After a brief introduction to data visualization, the second half of the semester will focus on the creation of web-based information dashboards and websites that tell stories with data, all of which are important for data science. GUI design patterns and usability testing will help ensure that each application offers a compelling user experience (UX). Topics for the course will include: Web programming overview o Model-View-Controller (MVC) architecture o Client side o Server side o Data management backend o Single-page applications (SPAs) Analysis and design o Functional and nonfunctional requirements o Use cases o Functional specification o Design specification Client-side programming o HTML 5 + CSS 3 o JavaScript o JavaScript libraries: jquery, React o Responsive websites o AJAX o Framework: AngularJS Server-side programming o Framework: Node.js + Express o MEAN stack: MongoDB + Express + Angular + Node.js o MERN stack: MongoDB + Express + React + Node.js o Search engine optimization (SEO) Data management o NoSQL database: MongoDB o Content management: WordPress o RESTful web services Data visualization Information dashboards Websites that tell stories with data Compelling user experience (UX) o GUI design patterns o Usability testing CMPE 280 Web UI Design and Development, Spring 2019, Ron Mak Page 2 of 8

Course Learning Outcomes (CLO) Upon successful completion of this course, students will be able to: CLO 1: Requirements analysis: Analyze a problem s requirements and design an application to meet them. CLO 2: Client side: Use HTML 5, CSS 3, JavaScript, libraries such as jquery, and frameworks such as AngularJS. CLO 3: Server side: Use technologies such as node.js and MongoDB and frameworks such as Express to create RESTful web services. CLO 4: Web applications development: Execute the complete process of designing, developing, deploying, and maintaining applications using web standards. Implement techniques such as search engine optimization (SEO). CLO 5: Data science: Use data visualization to design and implement web-based information dashboards and web applications that tell stories with data. CLO 6: User experience (UX): Employ GUI design patterns and usability testing to create web applications that offer a compelling UX. You will follow industry-standard best practices and use software development tools that are common in today s software industry. You will develop the critical job skill of working in a small project team. CMPE 280 Web UI Design and Development, Spring 2019, Ron Mak Page 3 of 8

Recommended texts Web standards, tools, and techniques evolve too rapidly for published books to keep up. Rely on the Internet for the most current information. JavaScript & jquery: The Missing Manual, 3 rd edition David Sawyer McFarland O Reilly Media, 2014 978-1491947074 Getting MEAN with Mongo, Express, Angular, and Node Simon Holmes Manning Publications, 2015 978-1617292033 Express in Action: Writing, Building, and Testing Node.js Applications Evan Hahn Manning Publications, 2016 978-1617292422 Learning React Kirupa Chinnathambi Addison-Wesley Professional, 2016 978-0134546315 RESTful Web API Design with Node.js, 2 nd edition Valentin Bojinov Packt Publishing, 2015 978-1783985869 Storytelling with Data: A Data Visualization Guide for Business Professionals Cole Nussbaumer Knaflic Wiley, 2015 978-1119002253 Designed for Use: Create Usable Interfaces for Applications and the Web, 2 nd edition Lukas Mathis Pragmatic Bookshelf, 2017 978-1680501605 Designing Interfaces: Patterns for Effective Interaction Design, 2 nd edition Jenifer Tidwell O'Reilly Media, 2011 978-1449379704 Books on data visualization and information dashboard design by Edward Tufte and Stephen Few CMPE 280 Web UI Design and Development, Spring 2019, Ron Mak Page 4 of 8

Course Requirements and Assignments You will form project teams of four students each. Team membership is mandatory for this class. The teams will last throughout the semester. Once the teams are formed, you will not be allowed to move from one team to another, so form your teams wisely! Team-based assignments will provide practice with web tools and techniques, and opportunities for research. Each student team will also have a semester design project to develop a significant web application that tells a story with data. The assignments will incrementally help each team develop its project, and each assignment will take one or two weeks. Each student on a team will receive the same score for each team assignment and the team project. Each team will submit its assignments and project into Canvas, which will display the scoring rubric. At the end of the semester, each team will give a presentation and demo of its design project, and students will help to score each presentation. Each assignment and project will be worth up to 100 points. Late assignments will lose 20 points and an additional 20 points for each 24 hours after the due date. The university s syllabus policies: University Syllabus Policy S16-9 at http://www.sjsu.edu/senate/docs/s16-9.pdf. Office of Graduate and Undergraduate Programs Syllabus Information web page at http://www.sjsu.edu/gup/syllabusinfo/ Success in this course is based on the expectation that students will spend, for each unit of credit, a minimum of 45 hours over the length of the course (normally 3 hours per unit per week with 1 of the hours used for lecture) for instruction or preparation/studying or course related activities including but not limited to internships, labs, clinical practica. Other course structures will have equivalent workload expectations as described in the syllabus. Exams The midterm and final examinations will be closed book. There can be no make-up midterm examination unless there is a documented medical emergency. Make-up final examinations are available only under conditions dictated by University regulations. The exams will test understanding (not memorization) of the material taught during the semester and now well each of you participated in your team assignments and project. Grading Information Your individual final class grade will be weighted as follows: 30% Assignments* 35% Project* 15% Midterm exam** 20% Final exam** * team scores ** individual scores Course grades will be based on a curve. Per CMPE Department policy, the median total score will earn a B+. Approximately one third of the class will earn higher grades, and another one third will earn lower grades. CMPE 280 Web UI Design and Development, Spring 2019, Ron Mak Page 5 of 8

Postmortem report At the end of the semester, each student must also turn in a short (under 1 page) individual postmortem report that includes: A brief description of what you learned in the course. An assessment of your accomplishments for your team assignments and design project. An assessment of each of your other project team members. Only the instructor will see these reports. How your teammates evaluate you may affect your course grade. Classroom Protocol It is very important for each student to attend classes and to participate. Mobile devices in silent mode, please. University Policies Per University Policy S16-9, university-wide policy information relevant to all courses, such as academic integrity, accommodations, etc. will be available on Office of Graduate and Undergraduate Program s Syllabus Information web page at http://www.sjsu.edu/gup/syllabusinfo/. CMPE 280 Web UI Design and Development, Spring 2019, Ron Mak Page 6 of 8

CMPE 280 Web UI Design and Development Section 2 Spring 2019 Course Schedule (subject to change with fair notice) Week Date Topics 1 Jan 24 Web programming overview HTTP protocol Naked HTML: lists, tables, links, and images HTML user input components: push buttons, checkboxes, radio buttons, menus Form programming teams 2 Jan 29 Jan 31 3 Feb 5 Feb 7 4 Feb 12 Feb 14 5 Feb 19 Feb 21 6 Feb 26 Feb 28 7 Mar 5 Mar 7 8 Mar 12 Mar 14 Model-view-controller (MVC) architecture Node.js server-side programming The Express framework Functional and nonfunctional requirements Use cases The Functional Specification CSS 3 stylesheets Document object model (DOM) JavaScript client-side programming Session management Cookies User authentication HTML 5 canvas drawing JavaScript animation Mouse and keyboard events DOM manipulation Object-oriented JavaScript AJAX The jquery library AJAX support jquery User Interface Toolkit (jqueryui) Search engine optimization (SEO) Content management and WordPress Midterm exam Tuesday, March 12 NoSQL databases MongoDB Documents and collections Express + MongoDB CMPE 280 Web UI Design and Development, Spring 2019, Ron Mak Page 7 of 8

Week Date Topics 9 Mar 19 Mar 21 10 Mar 26 Mar 28 Apr 1-5 11 Apr 9 Apr 11 12 Apr 16 Apr 18 13 Apr 23 Apr 25 14 Apr 30 May 2 15 May 7 May 9 Final Thursday, exam May 16 Database CRUD actions and HTTP verbs The REST API and RESTful web services Data visualization Web-based information dashboards Pre-attentive attributes Data analysis Data visualization tools Choose the right charts Websites that tell stories with data Spring break GUI design patterns Organization design patterns Navigation design patterns Page layout design patterns List design patterns Action design patterns User input design patterns AngularJS 2-way data binding MongoDB + Express + AngularJS + node.js (MEAN stack) Single-page application (SPA) The React library MongoDB + Express + React + node.js (MERN stack) Usability testing Project presentations Project presentations Time: 9:45 - noon Room: DMH 227 CMPE 280 Web UI Design and Development, Spring 2019, Ron Mak Page 8 of 8