1. 概述
在本文中,我们将介绍由弹簧MVC提供的核心组织弹簧框架,组织弹簧框架。.
2. Maven依赖关系
让我们从pom.xml文件中的弹簧上下文依赖关系开始:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.2.2.RELEASE</version>
</dependency>
可以在此处找到最新版本的弹簧上下文依赖项。
对于模型和视图,弹簧网依赖关系是必需的:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.2.2.RELEASE</version>
</dependency>
最新版本的弹簧网依赖可以在这里找到。
而且,如果我们使用百里叶作为我们的观点,我们应该将这种依赖性添加到pom.xml:
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring5</artifactId>
<version>3.0.11.RELEASE</version>
</dependency>
最新版本的百里叶依赖可以在这里找到。
3. Model
让我们从最基本的概念开始 - 模型。
简而言之,该模型可以提供用于呈现视图的属性。
若要提供包含可用数据的视图,我们只需将此数据添加到其 Model 对象中即可。此外,具有属性的映射可以与模型实例合并:
@GetMapping("/showViewPage")
public String passParametersWithModel(Model model) {
Map<String, String> map = new HashMap<>();
map.put("spring", "mvc");
model.addAttribute("message", "Baeldung");
model.mergeAttributes(map);
return "viewPage";
}
4. ModelMap
就像上面的模型界面一样,模型映射也用于传递值来呈现视图。
ModelMap 的优点是它使我们能够传递一组值,并将这些值视为在 Map 中一样:
@GetMapping("/printViewPage")
public String passParametersWithModelMap(ModelMap map) {
map.addAttribute("welcomeMessage", "welcome");
map.addAttribute("message", "Baeldung");
return "viewPage";
}
5. ModelAndView
将值传递到视图的最后一个接口是模型和视图。
此接口允许我们在一次返回中传递Spring MVC所需的所有信息:
@GetMapping("/goToViewPage")
public ModelAndView passParametersWithModelAndView() {
ModelAndView modelAndView = new ModelAndView("viewPage");
modelAndView.addObject("message", "Baeldung");
return modelAndView;
}
6. View
我们放置在这些模型中的所有数据都由视图使用 - 通常,模板化视图来呈现网页。
如果我们有一个以控制器的方法为目标的百里叶模板文件作为他们的视图。通过模型传递的参数可以从百里叶 HTML 代码中访问:
<!DOCTYPE HTML>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>Title</title>
</head>
<body>
<div>Web Application. Passed parameter : th:text="${message}"</div>
</body>
</html>
Copy
此处传递的参数通过语法 ${message}(称为占位符)使用。Thymeleaf 模板引擎会将此占位符替换为通过模型传递的同名属性的实际值。
7. 结论
在这个快速教程中,我们讨论了春季MVC中的三个核心概念 - 模型,模型映射和模型和视图。我们还查看了视图如何利用这些值的示例。
与往常一样,所有这些示例和代码片段的实现都可以在Github上找到。