SpringMVC视图
-
SpringMVC中的视图是View接口,视图的作用渲染数据,将模型Model中的数据展示给用户
-
SpringMVC视图的种类很多,默认有转发视图(
InternalResourceView
)和 重定向视图(RedirectView
)
配置视图:
- 当工程引入jstl的依赖 ,转发视图会自动转换为JstlView
- 若使用的视图技术为Thymeleaf,在SpringMVC的配置文件中配置了Thymeleaf的视图解析器 ,由此视图解析器解析之后所得到的是ThymeleafView
ThymeleafView
当控制器方法中所设置的视图名称没有任何前缀时,此时的视图名称会被SpringMVC配置文件中所配置的视图解析器解析 ,视图名称拼接视图前缀和视图,后缀所得到的最终路径,会通过转发的方式实现跳转
HelloController.java
java
@RequestMapping("/hello")
public String sayHello(){
//进行thymeleaf渲染+转发
return "success";
}
转发视图
SpringMVC中默认的转发视图是InternalResourceView
SpringMVC中创建转发视图的情况:
当控制器方法中所设置的视图名称以"forward:"为前缀时,创建
InternalResourceView
视图,此时的视图名称不会被SpringMVC配置文件中所配置的视图解析器解析 ,而是会将前缀"forward:"去掉 ,剩余部分作为最终路径通过转发的方式实现跳转例如:"forward:/","forward:/employee"
TestViewController.java
java
@RequestMapping("/testForwardView")
public String testForwardView(){
//只会转发请求,不会对thymeleaf进行渲染,在转发后再定位到上面的sayHello()方法后再返回"逻辑视图",最后交由DispatcherServlet控制器进行处理(因为无法通过路径直接访问到对应的网页,所以这种"多此一举"的方式基本不用)
return "forward:/hello";
}
重定向视图
SpringMVC中默认的重定向视图是RedirectView
SpringMVC中创建重定向视图的情况:
当控制器方法中所设置的视图名称以"redirect:"为前缀时,创建
RedirectView
视图,此时的视图名称不会被SpringMVC配置文件中所配置的视图解析器解析 ,而是会将前缀"redirect:"去掉 ,剩余部分作为最终路径通过重定向的方式实现跳转例如:"redirect:/","redirect:/employee"
TestViewController.java
java
@RequestMapping("/testRedirectView")
public String testRedirectView(){
//只会重定向请求,不会对thymeleaf进行渲染(重定向因为无法对thymeleaf进行渲染,所以这里相当于重定向发送"/hello"请求(GET方式),再交由DispatcherServlet控制器进行处理)
return "redirect:/hello";
}
注意:
- forward转发方式会将请求方式转发,包括POST、PUT、DELETE等请求方式
- redirect重定向方式则是会将请求方式转为GET方式
视图控制器view-controller
当控制器方法中,若仅仅只用来实现页面跳转 ,即只需要设置视图名称 时,可以将处理器方法使用<view-controller>
标签进行表示,就可以省略控制器方法
在resources
目录下的SpringMVC.xml
(通过扩展配置方式放到了其它目录下 )
xml
<!--视图控制器:为当前的请求直接设置视图名称实现页面跳转-->
<!--
path:设置处理的请求地址
view-name:设置请求地址所对应的视图名称
-->
<mvc:view-controller path="/" view-name="index" />
当SpringMVC中设置任何一个
<mvc:view-controller>
时,其他控制器中的请求映射将全部失效 ,此时需要在SpringMVC的核心配置文件中设置开启mvc注解驱动 的标签(自动加载ReuestMappingHandlerMapping(处理映射器)
和RequestMappingHandlerAdapter(处理适配器)
,集成jackson进行对象或集合的json格式字符串的转换)来实现------实现将请求按配置顺序 依次传递给控制器进行处理,直到有可以处理的控制器,而不是按照某种特定的优先级 来让优先级高的控制器单独处理后就返回结果
在SpringMVC.xml
中添加开启(没有顺序要求)
xml
<!--
开启mvc注解驱动:
需要使其它控制器请求映射和视图控制器同时生效时(按照配置文档顺序进行请求匹配)
需要controller返回一个 javabean、list、map等数据的json对象时
需要访问静态资源时
需要处理Ajax的一些请求时
-->
<mvc:annotation-driven/>