SpringMVC中的视图是View接口,视图的作用渲染数据,将模型Model中的数据展示给用户



        SpringMVC视图的种类很多,默认有转发视图和重定向视图




        当工程引入jstl的依赖,转发视图会自动转换为JstlView




        若使用的视图技术为Thymeleaf,在SpringMVC的配置文件中配置了Thymeleaf的视图解析器,由此视图解析器解析之后所得到的是ThymeleafView





1、ThymeleafView



        当控制器方法中所设置的视图名称没有任何前缀时,此时的视图名称会被SpringMVC 配置文件中所配置的视图解析器解析,视图名称拼接视图前缀和视图后缀所得到的最终路径,会通过转发的方式实现跳转




代码示例:



Java代码:



@Controller
public class PortalController {

    @RequestMapping("/")
    public String index() {
        return "index";
    }
}



@Controller
@RequestMapping("/test/view")
public class TestViewController {

    @RequestMapping("/thymeleaf")
    public String testThymeleafView() {
        return "target";
    }
}



index代码:



<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8" xmlns:th="http://www.thymeleaf.org">
    <title>首页</title>
</head>
<body>
    <h1>首页</h1>
    
    <a th:href="@{/test/view/thymeleaf}">测试 ThymeleafView 视图的跳转</a><br/>

</body>
</html>



target代码:



<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Target</title>
</head>
<body>
    <h1>Hello World</h1>
</body>
</html>

2、转发视图



SpringMVC中默认的转发视图是 InternalResourceView




SpringMVC中创建转发视图的情况:



        当控制器方法中所设置的视图名称以"forward:"为前缀时,创建InternalResourceView视图,此时的视



图名称不会被SpringMVC配置文件中所配置的视图解析器解析,而是会将前缀"forward:"去掉,剩余部



分作为最终路径通过转发的方式实现跳转



        例如"forward:/","forward:/employee




该方法与  ThymeleafView 转发方式区别:

        ThymeleafView 转发页面的结果经过 Thymeleaf 渲染(常用)

        InternalResourceView 页面转发只是单纯的页面跳转没有经过 渲染 (不常用)

代码示例:

Java代码:

@RequestMapping("/forward")
    public String testForward() {
        return "forward:/test/view/thymeleaf";
    }



index代码:




<a th:href="@{/test/view/forward}">测试 InternalResourceView 视图的跳转</a><br/>

3、重定向视图



        SpringMVC中默认的重定向视图是 RedirectView




        当控制器方法中所设置的视图名称以"redirect:"为前缀时,创建RedirectView视图,此时的视图名称不会被SpringMVC配置文件中所配置的视图解析器解析,而是会将前缀"redirect:"去掉,剩余部分作为最终路径通过重定向的方式实现跳转



        例如"redirect:/","redirect:/employee"





注:

        重定向视图在解析时,会先将redirect:前缀去掉,然后会判断剩余部分是否以/开头,若是则会自动拼接上下文路径




代码示例:



Java代码:



@RequestMapping("/redirect")
    public String testRedirect() {
        return "redirect:/test/view/thymeleaf";
    }



index代码:



<a th:href="@{/test/view/redirect}">测试 RedirectView 视图的重定向</a><br/>

4、视图控制器view-controller



        当控制器方法中,仅仅用来实现页面跳转,不需要其他请求或响应等操作时,即只需要设置视图名称时,可以将处理器方法使用view-controller标签进行表示。




代码示例:



在 springmvc.xml 配置文件中设置标签:



<!--
		path:设置处理的请求地址
		view-name:设置请求地址所对应的视图名称
	-->
	<mvc:view-controller path="/" view-name="index"/>

将 PortalController 类中 首页跳转的代码注释掉:

@Controller
public class PortalController {

    // @RequestMapping("/")
    // public String index() {
    //     return "index";
    // }
}



注: 当SpringMVC中设置任何一个view-controller时,其他控制器中的请求映射将全部失效,此时需 要在SpringMVC的核心配置文件中设置开启mvc注解驱动的标签: <mvc:annotation-driven />



<!-- 开启mvc注解驱动 -->
	<mvc:annotation-driven/>
	<!--
		path:设置处理的请求地址
		view-name:设置请求地址所对应的视图名称
	-->
	<mvc:view-controller path="/" view-name="index"/>