Skip to main content

Web Development (10 cr)

Code: TX00EY23-3001

General information


Enrollment
29.05.2023 - 31.07.2023
Registration for the implementation has ended.
Timing
21.08.2023 - 15.10.2023
Implementation has ended.
Number of ECTS credits allocated
10 cr
Local portion
10 cr
Mode of delivery
On-campus
Unit
(2019-2024) School of ICT
Campus
Myllypurontie 1
Teaching languages
English
Seats
0 - 55
Degree programmes
Degree Programme in Information Technology
Teachers
Sami Ben Cheikh
Vesa Ollikainen
Groups
ICT22-SW
Software Engineering
Course
TX00EY23

Implementation has 17 reservations. Total duration of reservations is 49 h 30 min.

Time Topic Location
Mon 21.08.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
MPA5026 Luentosali
Thu 24.08.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Mon 28.08.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Thu 31.08.2023 time 10:30 - 12:00
(1 h 30 min)
Web Development TX00EY23-3001
Online
Tue 05.09.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Thu 07.09.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Tue 12.09.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Wed 13.09.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Tue 19.09.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Thu 21.09.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Tue 26.09.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Thu 28.09.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Tue 03.10.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Thu 05.10.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Tue 10.10.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Thu 12.10.2023 time 09:00 - 12:00
(3 h 0 min)
Web Development TX00EY23-3001
Online
Fri 13.10.2023 time 09:00 - 12:00
(3 h 0 min)
Exam: Web Development TX00EY23-3001
MPB1005 Tapahtumasali
Changes to reservations may be possible.

Objective

After completing the course, the student
• knows the principles of building full stack web applications
• knows client and server side technologies and understands how communication between client and server sides is implemented
• understands how to test a web application.

Content

Front end side / client side programming
• HTML, CSS
• JavaScript
• DOM
• Asynchronous communication
• Client side application frameworks (e.g. Vue.js, React.js)

Communication and data transfer
• HTTP
• REST
• JSON

Back end side / server side programming
• JavaScript, Node.js
• Server side application frameworks (Express)
• Use of databases (SQL and NoSQL)

Testing of full stack applications

Location and time

The course will be conducted using a blended approach.

The first and final classes will be held on campus, while the remaining sessions will take place virtually on Zoom.
The initial class is scheduled for August 21, 2023, from 09:00 to 12:00, and will be held in Room MPA5026 (Myllypuro Campus)
Last session is scheduled for October 13, 2023, 09.00 - 12.00 , and will be held in Room MPB1005 (Myllypuro Campus)

Materials

Course materials will be provided in advance, enabling you to come prepared for each session and group work.
You'll receive clear guidelines on when and how to utilize ChatGPT effectively.
There is no required textbook for the course; all necessary materials will be furnished by the instructor.

Teaching methods

The course will be conducted using a blended approach.

The first and final classes will be held on campus, while the remaining sessions will take place virtually on Zoom.

The teaching strategy used in this course follows a MODIFIED version of team-based learning.

Student workload

This course is worth 10 ECTS. The workload is 27 hours per credit, ensuring a comprehensive learning journey. In addition to the scheduled sessions, you should allocate time each week for self-study and group work.

Content scheduling

This course is structured into two distinct parts: Backend Web Development and Frontend Web Development.

Part A: Backend Web Development

Module 1/3: Introduction to Backend Development
Browser Engines vs. JavaScript Engines
V8 JavaScript Engine
Node.js Fundamentals
Introduction to Express.js Framework

Module 2/3: Building with Express.js
Express.js Routers
Express.js Middleware
Express.js Controllers
Working with MongoDB and Mongoose
Authentication
Authorization and Roles
API Documentation and Best Practices

Module 3/3: Advanced Concepts and Deployment
Node Modules: Import vs. CommonJS Require
Error Handling and Logging
Where to Go Next in BackendDevelopment

Part B: Frontend Web Development

Module 1/3: Introduction to Frontend Development
Single Page Applications (SPAs)
Introduction to Ajax
DOM vs. Virtual DOM
Introduction to React.js

Module 2/3: Building with React.js
React Components and Component Structure
React JSX: Syntax and Benefits
Styling React Components
Passing Data with React Props
Working with Lists in React
State Management with useState Hook
Side Effects and Lifecycle with useEffect Hook
Context API with useContext Hook
State Management with useReducer Hook
React Router
Custom Hooks

Module 3/3: Advanced Topics and Integration
React Authentication Techniques
User Administration and CRUD Operations
Where to Go Next in Frontend Development

Further information

This course (Web Development TX00EY23-3001) runs in parallel with the "Web Project" course, forming a comprehensive curriculum. These two courses equip you with key programming skills in both front-end and back-end technologies. As the digital landscape evolves, the ability to create dynamic and interactive web applications is more valuable than ever. Throughout this journey, you'll learn to develop and deploy real-world full stack applications, secure them, and deploy them effectively.

This course starts with fundamental concepts of web development. As you progress you will be introduced to additional theory, web technologies, tools and libraries.

In addition, you'll gain collaborative experiences through group activities. You will team up with your peers and you will be introduced to soft skills such as, problem solving, discipline, lifelong learning and communication.

By the end of the course, you will be equipped with enough knowledge to put together multiple technologies. Not only you will learn how to code, but also how to think and act like a programmer.

Evaluation scale

0-5

Assessment criteria, satisfactory (1)

The student
• has achieved the objectives of the course to a satisfactory level
• is able to identify and define the concepts, models and in the subject area of the course
• has completed the learning tasks required for the course to the minimum standard.

Assessment criteria, good (3)

The student
• has achieved the objectives of the course well
• is able to identify, define and use the concepts, models and tools in the subject area of the course
• has completed the learning tasks of the course at a good level.

Assessment criteria, excellent (5)

The student
• has achieved the objectives of the course with excellent marks
• is able to identify, define and use and apply the concepts and models in the subject area of the course in a variety of ways
• has completed the learning tasks of the course at an excellent level and has put considerable own effort into their solutions.

Assessment criteria, approved/failed

The student
• has achieved the objectives of the course
• is able to identify and define concepts and models in the subject area of the course
• has completed the learning tasks required for the course.

Assessment methods and criteria

The grading structure is designed to reflect your understanding of both backend and frontend concepts, as well as your ability to integrate them effectively.

The assessment considers in-class activities, peer assessment and Exam.
The course is designed to enable every student to succeed, with three grading levels: Level 1 (Grade 1), Level 2 (Grades 2-3), and Level 3 (Grades 4-5).
The potential to achieve the highest grade is available to every student, reflecting the effort and dedication invested in the course.

Your grade will be determined based on the following components:

In-Class Activities (30%)
Individual homework (30%)
Feedback (5%)
Exam (35%)

Qualifications

1st year studies (Orientation to Information Technology 60 ECTS) of the Information Technology Degree Programme.

Go back to top of page