SpringMVC-视图

六、SpringMVC的视图

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

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

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

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

1、ThymeleafView

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

html中的设置

<a th:href="@{/testThymeleafView}">测试ThymeleafView</a><br>

控制器中的设置

//使用ThymeleafView视图
@RequestMapping("/testThymeleafView")
public String testThymeleafView(){
    return "success";
}

2、转发视图

SpringMVC中默认的转发视图是InternalResourceView

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

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

例如"forward:/"(表示转发到首页),"forward:/employee"

html中的设置

<a th:href="@{/testForward}">测试转发视图InternalResourceView</a><br>

控制器中的设置

//使用转发视图InternalResourceView
@RequestMapping("/testForward")
public String testForward(){
    //实现转发到/testThymeleafView页面的功能
    //"forward:/xxx在被解析时,先将前缀forward:截掉,然后转发到/xxx页面
    return "forward:/testThymeleafView";
}

3、重定向视图

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

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

例如"redirect:/"(表示重定向到首页),"redirect::/employee"

转发视图发生在服务器内部,因此不能跨域,只能访问服务器内部资源。重定向视图发生在浏览器,因此可以跨域,例如可以重定向访问百度。

html中的设置

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

控制器中的设置

//使用重定向视图RedirectView
@RequestMapping("/testRedirect")
public String testRedirect(){
    //实现重定向到/testThymeleafView页面的功能
    //"redirect:/xxx在被解析时,先将前缀redirect:截掉,然后重定向到/xxx页面
    return "redirect:/testThymeleafView";
}

4、视图控制器view-controller

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

首先将控制器中跳转html首页的index()方法注释掉,然后再进入resources root中的核心配置文件xml内设置。

核心配置文件xml中的设置

<!--和TestController.java中的index()方法相同,如果控制器方法(index())中
    只用设置视图名称而其它请求处理过程,则可以使用view-controller代替。但
    原来在控制器中所写的所有请求映射将全部失效。
-->
<mvc:view-controller path="/" view-name="index" />
<!--开启MVC的注解驱动
    开启注解驱动后,由于view-controller导致的原来在控制器中的所有请求映射
    全部重新有效。
-->
<mvc:annotation-driven />

注:

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

5、使用Jsp创建视图

除了resources root中的核心配置文件springMVC.xml与第二章第五节中的配置不同之外,其余步骤同第二章。

springMVC.xml配置

<!--自动扫描包-->
<context:component-scan base-package="com.atguigu.mvc.controller" />
​
<!--配置InternalResource视图解析器
    使用Jsp视图时,不用像thymeleaf的视图解析器那样写
-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/templates/" />
    <property name="suffix" value=".jsp" />
</bean>

Jsp中的设置

index.jsp创建于webapp目录下,作为首页。其余jsp同以前的html文件一样,创建在templates目录下。

<h1>首页</h1>
<%--使用thymeleaf时,超链接格式为:<a th:href="@{/xxx}">...</a>
    使用jsp时,路径由浏览器解析,所以还需要加上上下文路径,但由于上
    下文路径会改变,以此使用"${}"来动态获取上下文路径,超链接格式为:
    <a href="${pageContext.request.contextPath}/xxx">...</a>
--%>
<a href="${pageContext.request.contextPath}/success">success.jsp</a>

success.jsp创建于templates目录下。

成功

控制器

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

注:使用jsp时,同样可以像thymeleaf一样使用转发视图和重定向视图。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值