Spring MVC 页面渲染( render view )

超、凢脫俗 2022-05-25 02:08 367阅读 0赞

一、理解view解析过程

1.1 从逻辑view到物理view

在Spring MVC 中,controllers不会负责具体的页面渲染,它仅仅是调用业务逻辑并返回model数据给view层,至于view层具体怎么用HTML展现,由专门的view层具体负责,这就是MVC模式,业务层与展示层是松耦合的。那么,Spring MVC是如何解耦合请求处理逻辑和页面渲染的呢?

我们在Spring MVC配置介绍文章中已经知道,controller在处理外业务逻辑之后会返回一个逻辑view的字符串,那么Spring MVC是怎么根据这个逻辑view名找到真正的物理view页面呢?这个工作就由Spring的ViewResolvers负责。

对于普通的JSP页面,最常用到的就是view resolver就是InternalResourceViewResolver,它有两个属性,一个是匹配物理view的前缀,一个是后缀。前缀一般就是view页面的路径位置,后缀就是文件的格式,而前缀后缀之间的就是逻辑view名称。

  1. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  2. <property name="prefix" value="/WEB-INF/views/" />
  3. <property name="suffix" value=".jsp" />
  4. </bean>
  • 1
  • 2
  • 3
  • 4
  • 5

比如按照上面的配置,如果controller返回的逻辑view名称是home的话,InternalResourceViewResolver会根据这个逻辑view名home找到其对应的实际物理view:/WEB-INF/views/home.jsp

  1. @Controller
  2. @RequestMapping(value = "/")
  3. public class HomeController {
  4. @RequestMapping(method= RequestMethod.GET)
  5. public String home() {
  6. return "home";
  7. }
  8. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

这里写图片描述

1.2 ViewResolver相关接口

ViewResolver接口:

  1. public interface ViewResolver {
  2. View resolveViewName(String var1, Locale var2) throws Exception;
  3. }
  • 1
  • 2
  • 3
  • 4

这个接口很简单,当我们传入一个逻辑view名和Locale对象,就会返回一个View实例。

View接口:

  1. public interface View {
  2. String getContentType();
  3. void render(Map<String, ?> var1, HttpServletRequest var2, HttpServletResponse var3) throws Exception;
  4. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

View接口的职责就是接收model对象、Request对象、Response对象,并渲染输出结果给Response对象。如果我们要自己写一个ViewResolver也很简单,我们只需要实现ViewResolver和View两个接口,在View接口中把需要渲染的内容输出到Response对象中去就可以了。

1.3 各种现成的ViewResolver

当然,我们基本上不需要自己去写ViewResolver,spring mvc为我们提供了各种各样的ViewResolver:
这里写图片描述

上面虽然列了很多个ViewResolver,但我们具体用哪个好呢?其实上面的每个ViewResolver都对应着一种view页面的实现技术,比如InternalResourceViewResolver就是用来处理JSP页面,TilesViewResolver主要处理Apache Tiles Views,FreeMarkerViewResolverVelocityViewResolver分别对应着FreeMarkerVelocity Template页面渲染技术。

二、创建一个JSP View

无可否认,在Java web编程领域,历史最悠久的页面处理技术便是JSP。所以,这里我们就拿JSP技术来展示spring是如何渲染页面的。

Spring有两种方式来支持JSP页面:

  1. 1. InternalResourceViewResolver可以用来解析JSP文件,当然,它也支持JSP页面使用JavaServer Standard LibraryJSTL
  2. 2. Spring自己也提供了两种JSP 标签类库,一种是表单数据绑定标签库,另一种是提供了一些通用特性的标签库
  • 1
  • 2
  • 3

无论我们使用JSTL还是Spring JSP标签类库,我们都需要配置一个ViewResolver来解析JSP页面。当然一些其他的ViewResolver也可以解析JSP页面,但InternalResourceViewResolver是专门针对JSP技术设计的解析器,所以对于JSP页面,它用起来最简单也最方便。

2.1 InternalResourceViewResolver的配置

其实InternalResourceViewResolver的配置在1.1节已经介绍了,它可以直接把一个逻辑view名映射到转实际渲染数据的物理view页面。如果按照我们这样的配置:

  1. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  2. <property name="prefix" value="/WEB-INF/views/" />
  3. <property name="suffix" value=".jsp" />
  4. </bean>
  • 1
  • 2
  • 3
  • 4
  • 5

那么对于下面这些逻辑view名,InternalResourceViewResolver则会将其映射成相应的JSP页面:

  • home 解析成 /WEB-INF/views/home.jsp
  • productList 解析成 /WEB-INF/views/productList.jsp
  • books/detail 解析成 /WEB-INF/views/books/detail.jsp

上面例子中还可以看到,当我们的逻辑名称中含有反斜线/时,解析器会将其解析成资源文件的路径,这样我们就可以对页面资源文件进行目录管理了。

2.2 解析标准的JSTL文件

如果要想在JSP中使用JSTL标签很简单,我们只需在InternalResourceViewResolver中指定一个viewClass属性即可:

  1. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" >
  2. <property name="prefix" value="/WEB-INF/views/" />
  3. <property name="suffix" value=".jsp" />
  4. <property name="viewClass" value="org.springframework.web.servlet.view.JstlView />
  5. </bean>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

2.3 使用Spring JSP类库

上面已经讲过,Spring JSP提供了两种类库,一种是表单数据绑定标签库,另一种提供了更多样话的通用标签库。

2.3.1 使用表单数据绑定标签库

Spring的表单数据绑定标签库提供了14个标签,它和普通标签的区别就是能够将表单属性和model对象属性绑定在一起。要想使用表单数据绑定标签库,只需要在JSP页面中声明:

  1. <%@ taglib uri="http://www.springframework.org/tags/form" prefix="sf" %>
  • 1
  • 2

标签库中的14个标签:
这里写图片描述
下面举个例子,我们使用这个标签库来重写一个注册页面:

  1. <sf:form method="POST" commandName="user">
  2. First Name: <sf:input path="firstName" /><br/>
  3. Last Name: <sf:input path="lastName" /><br/>
  4. Email: <sf:input path="email" /><br/>
  5. Username: <sf:input path="username" /><br/>
  6. Password: <sf:password path="password" /><br/>
  7. <input type="submit" value="Register" />
  8. </sf:form>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

commandName:对应后端model数据对象名称,也就是Model中的对应的key值

  1. @RequestMapping(value="/register", method= RequestMethod.GET)
  2. public String showRegistrationForm(Model model) {
  3. model.addAttribute("user",new User());
  4. return "register";
  5. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

path:我们可以看到form表单内部每个标签都有个path属性,这个属性对应的就是Model对象的属性

2.3.2 使用通用标签库

除了表单数据绑定标签库之外,Spring还提供了一个更加通用的标签库,要想使用这个更通用的标签库,只需要在JSP页面中添加:

  1. <%@ taglib uri="http://www.springframework.org/tags" prefix="s" %>
  • 1
  • 2

标签库中的标签:
这里写图片描述

发表评论

表情:
评论列表 (有 0 条评论,367人围观)

还没有评论,来说两句吧...

相关阅读

    相关 vue渲染render

    一、宏观上展现了Vue整体流程: ![vue-render-1.jpg][]   Vue推荐在绝大多数情况下使用`template`来创建你的HTML。然而在一些场景中,