SpringMVC 中的视图是 View 接口,视图的作用是渲染数据,将 Model 中的数据展示给用户。视图的种类有很多,默认有转发视图(InternalResourceView)和重定向视图(RedirectView)
ThymeleafView
当控制器方法中所设置的视图名称没有任何前缀时,此时的视图名称会被 SpringMVC 配置文件中所配置的视图解析器解析,视图名称拼接视图前缀和视图后缀所得到的最终路径,会通过转发的方式实现跳转,前面学习所使用的都是这个。
转发视图
SpringMVC 中默认的转发视图是 InternalResourceView,当控制器方法中所设置的视图名称以 "forward:" 为前缀时,创建 InternalResourceView 视图,此时的视图名称不会被 SpringMVC 配置文件中所配置的视图解析器解析,而是会将前缀 "forward:" 去掉,剩余部分作为最终路径通过转发的方式实现跳转
案例:
现在我们有如下控制器方法①可以用来跳转到 success 页面
@RequestMapping("/testThymeleafView")
public String testThymeleafView(){
return "success";
}
然后我们想在另外一个控制器方法中跳转到控制器方法①中,然后再由控制器方法①跳转到 success 页面,在这种情况下我们是不能直接在控制器中返回 "/testThymeleafView" 的,因为这样会被 thymeleaf 解析器解析为一个页面。在这种情况下我们就可以使用 "forward:"
@RequestMapping("/testForward")
public String testForward(){
return "forward:/testThymeleafView";
}
前台
成功页面:地址栏为 testForward ,并且浏览器只发送了一次请求
重定向视图
SpringMVC 中默认的重定向视图是 RedirectView,使用 "redirect:" 为视图名称前缀,此时视图名称不会被 SpringMVC 配置文件中所配置的视图解析器解析,而是会将前缀 "redirect:" 去掉,剩余部分作为最终路径通过重定向的方式实现跳转
案例:
使用重定向的方式跳转到 success 页面
前台:
控制器方法
@RequestMapping("/testRedirect")
public String testRedirect(){
return "redirect:/testThymeleafView";
}
成功页面:地址栏变为了 testThymeleafView ,并且浏览器发送了两次请求
视图控制器view-controller
当我们一个控制器方法只用来实现页面跳转,而不进行其他操作,即只需要设置视图名称时,我们可以在 SpringMVC 配置文件中使用 view-controller 标签进行表示处理器方法,但是要注意,一旦在 SpringMVC 中设置任何一个 view-controller 时,其他控制器中的请求映射将全部失效,此时需要在SpringMVC 的核心配置文件中设置开启 mvc 注解驱动的标签:<mvc:annotation-driven />
演示
在之前的案例中我们使用了下面这个控制器方法来进行向 success 页面的转发,现在我们将其注释掉
在 SpringMVC 的配置文件中配置如下信息,这里的 view-name 配置时可能会报错,我这里没有管他,可以正常跳转