目录
一.视图分类
(1)转发视图(Forward View):
(2)重定向视图(Redirect View):
(3)其他视图技术
二.转发视图
三.重定向视图
四.ThymeleafView
五.视图控制器view-controller
一.视图分类
在SpringMVC框架中,视图(View)是一个非常重要的概念,它负责将模型数据(Model)展示给用户。简单来说,视图就是用来生成用户界面的技术或模板。
(1)转发视图(Forward View)
当控制器(Controller)处理完用户的请求后,可以直接将模型数据传递给视图,然后视图根据这些数据生成用户界面。在这个过程中,用户的浏览器并不会进行页面刷新,数据是在服务器内部传递的。这种方式通常用于展示数据或者表单提交后的错误提示等。
例子:
张三向李四借钱,但李四没有钱。于是李四向王五借钱,并告诉王五将钱借给张三。这个过程中,张三只向李四请求借钱,但实际上钱是从王五那里借来的。
转发视图:用户请求 -> 服务器内部处理 -> 服务器直接返回结果给用户浏览器(用户不刷新页面)。
(2)重定向视图(Redirect View)
与转发视图不同,重定向视图会先发送一个重定向的响应给用户的浏览器,告诉浏览器去请求另一个URL。这样用户的浏览器会发起一个新的请求,服务器接收到新的请求后,再将模型数据传递给视图生成用户界面。这种方式通常用于表单提交后的成功页面,因为这样可以防止用户刷新页面时重复提交表单。
例子:
张三向李四借钱,但李四没有钱。李四告诉张三去找王五借钱。于是张三自己去找王五借钱,这个过程中,张三的请求被重定向到了王五那里。
重定向视图:用户请求 -> 服务器指示浏览器去请求另一个地址 -> 浏览器发起新的请求 -> 服务器处理并返回结果给浏览器(用户浏览器刷新页面)。
(3)其他视图技术
JSTL(JavaServer Pages Standard Tag Library):
当你的项目中包含了jstl依赖时,SpringMVC会自动将转发视图转换为JstlView。JSTL提供了一套丰富的标签库,可以方便地在JSP页面中进行条件判断、循环等操作,使得页面开发更加高效。
Thymeleaf:
Thymeleaf是一种现代的服务器端Java模板引擎,它可以与SpringMVC无缝集成。当你在SpringMVC的配置文件中添加了Thymeleaf视图解析器后,SpringMVC会使用这个解析器来处理Thymeleaf模板。Thymeleaf模板文件通常具有.html扩展名,它们可以包含动态数据和逻辑,使得页面开发更加灵活和强大。
二.转发视图
SpringMVC中默认的转发视图是InternalResourceView
SpringMVC中创建转发视图的情况:
当控制器方法中所设置的视图名称以"forward:"为前缀时,创建InternalResourceView视图,此时的视图名称不会被SpringMVC配置文件中所配置的视图解析器解析,而是会将前缀"forward:"去掉,剩余部分作为最终路径通过转发的方式实现跳转
例如"forward:/","forward:/employee"
@RequestMapping("/testForward")
public String testForward(){return "forward:/testHello";
}
这种方式的好处是,用户的浏览器不会重新发起一个新的请求,而是服务器内部直接将请求转发到了另一个页面。这样做可以保持用户的会话状态不变,比如用户登录状态等,同时也避免了用户重复提交表单的问题。
三.重定向视图
SpringMVC中默认的重定向视图是RedirectView
当控制器方法中所设置的视图名称以"redirect:"为前缀时,创建RedirectView视图,此时的视图名称不会被SpringMVC配置文件中所配置的视图解析器解析,而是会将前缀"redirect:"去掉,剩余部分作为最终路径通过重定向的方式实现跳转
例如"redirect:/","redirect:/employee"
@RequestMapping("/testRedirect")
public String testRedirect(){return "redirect:/testHello";
}
重定向视图(Redirect View)是 SpringMVC 中用于在处理完用户请求后,让浏览器发起一个新的请求去访问另一个页面的一种机制。通过在控制器方法中返回以 "redirect:" 开头的字符串来实现。这种方式对于改善用户体验和页面跳转控制非常有用。
四.ThymeleafView
当控制器方法中所设置的视图名称没有任何前缀时,此时的视图名称会被SpringMVC配置文件中所配置的视图解析器解析,视图名称拼接视图前缀和视图后缀所得到的最终路径,会通过转发的方式实现跳转。
@RequestMapping("/testHello")
public String testHello(){return "hello";
}
五.视图控制器view-controller
视图控制器(view-controller
)是 Spring MVC 中的一个特性,它允许你通过配置文件定义请求和视图之间的映射关系,而不是使用传统的控制器方法。这种方式简化了代码,因为你不需要创建一个完整的控制器类和方法,只需要定义请求路径和对应的视图名称即可。
<!--path:设置处理的请求地址view-name:设置请求地址所对应的视图名称
-->
<mvc:view-controller path="/testView" view-name="success"></mvc:view-controller>
这里的配置表示,当用户访问 /testView 这个路径时,Spring MVC 会自动将请求映射到名为 "success" 的视图上。"success" 是视图的名称,它通常对应一个 JSP、HTML 或其他类型的页面文件。这个过程不需要编写任何 Java 代码,只需要在配置文件中声明。
注意:
需要注意的是,如果你在 Spring MVC 应用中使用了 view-controller 标签,那么其他的控制器方法映射将不会生效。这是因为 view-controller 标签定义的映射具有最高的优先级。为了使其他的控制器方法映射生效,你需要在 Spring MVC 的核心配置文件中添加 <mvc:annotation-driven /> 标签,这个标签会开启 Spring MVC 的注解驱动功能,允许 Spring MVC 处理使用 @Controller 注解定义的控制器中的方法。