-
Notifications
You must be signed in to change notification settings - Fork 59
Lesson 11 (Model Classes and Model Binding)
Courtney Frey edited this page Apr 14, 2022
·
2 revisions
- The role of models in the MVC pattern
- The distinction between the functionality of models versus controllers and data services
- The data handling practice of assigning a unique id to objects created
- The use and benefits of model binding
- The job of the
@ModelAttribute
annotations
- Check with your course manager for any important announcements.
- Assignment 3 due date is approaching. With the knowledge they now have about model classes, they will be able to complete the assignment.
- Welcome to Day 18
- With all of the pieces of MVC in place, a review of all of the components and their relationships to each other and the client and the server is a good starting-off point.
- It may be tempting for students to associate models with data storage. Emphasize that our current data storage methods will be refactored and models are not raw data in a proper MVC app.
- To that point, a discussion on the object-oriented principles guiding data encapsulation and why we remove the data from the controller is useful.
- Demonstrate techniques for creating unique object ids and remind them why access to these fields should be limited.
- Discuss model binding and its benefits in general, and also what it looks like with Thymeleaf templates.
- The starter code for this studio is different from how students will have left things after last class's studio. Remind them to use branching so they can save their work and pull down the newer changes.
- The starter code contains a
Client
model that is different from the model class they will be creating. - There is not a lot of source code within the instructions and students may benefit from code comparison with their
coding-events
repository. It is not a bad idea to mention the similarities between the create event actions and the create user actions. - Some students may be confused by the request to create a model attribute for an error message. Try encouraging code experimentation here. If they are truly stuck, try explaining that it will just be a string that receives a value if the right condition is met, otherwise the text will be blank. Also, they can find a creative solution for this one. There are many ways to show an error.
- Leaving the username and email values in the form on an invalid submission can be deceptively simple.