Spring学习(六)渲染Web视图

一、创建JSP视图

  1. spring提供了两种支持jsp视图的方式:
  • InternalResourceViewResolver
    • InternalResourceViewResolver会将视图名解析为JSP文件
    • 如果JSP页面中使用了JSP标准标签库(JavaServer Pages Standard Tag Library, JSTL) 的话, InternalResourceViewResolver能够将视图名解析为JstlView形式的JSP文件, 从而将JSTL本地化和资源bundle变量暴露给JSTL的格式化(formatting) 和信息(message) 标签。
  • Spring
    • Spring提供了两个JSP标签库, 一个用于表单到模型的绑定, 另一个提供了通用的工具类特性。
  1. 配置适用于JSP的视图解析器
  • java方式
     @Bean
      public ViewResolver viewResolver() {
      InternalResourceViewResolver resolver = new InternalResourceViewResolver();
      resolver.setPrefix("/WEB-INF/views/");
      resolver.setSuffix(".jsp");
      return resolver;
    }
    
  • xml方式
    <beans:bean
      class="org.springframework.web.servlet.view.InternalResourceViewResolver">
      <beans:property name="prefix" value="/WEB-INF/views/" />
      <beans:property name="suffix" value=".jsp" />
    </beans:bean>
    
    • home将会解析为“/WEB-INF/views/home.jsp”
    • productList将会解析为“/WEB-INF/views/productList.jsp”
    • books/detail将会解析为“/WEB-INF/views/books/detail.jsp”
  1. 解析JSTL视图
    使用JSTL标签来处理格式化和信息,需要InternalResourceViewResolver将视图解析为JstlView,这需要设置InternalResourceViewResolver的viewClass属性:
  • java方式
    @Bean
    public ViewResolver viewResolver() {
      InternalResourceViewResolver resolver = new InternalResourceViewResolver();
      resolver.setPrefix("/WEB-INF/views/");
      resolver.setSuffix(".jsp");
      resolver.setViewClass(org.springframework.web.servlet.view.JstlView.class);
      return resolver;
    }
    
  • xml方式
    <beans:bean
      class="org.springframework.web.servlet.view.InternalResourceViewResolver">
      <beans:property name="prefix" value="/WEB-INF/views/" />
      <beans:property name="suffix" value=".jsp" />
      <beans:property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />
    </beans:bean>
    

4.使用spring的jsp库

  • 将表单绑定到模型上

    Spring的表单绑定jsp标签库包含了14个标签,它们中的大多数都用来渲染HTML中的表单标签。为了使用它们,需要在jsp页面中对其进行声明:
    <%@ taglib uri="http://www.springframework.org/tags/form" prefix="sf" %>
    如果在模型中Spitter对象的firstName属性值为Jack, 那么<sf:input path="firstName"/>所渲染的<input>标签中, 会存在value="Jack"。

    展现错误
    <sf:errors path="*" element="div" cssClass="errors" />

  • spring通用的标签库
    要使用Spring通用的标签库, 我们必须要在页面上对其进行声明:
    <%@ taglib uri="http://www.springframework.org/tags" prefix="s" %>

    展现国际化信息
    借助<s:message>来渲染文本
    <s:message code="spitter.welcome" text="Welcome" />
    <s:message>将会根据key为spittr.welcome的信息源来渲染文本。
    
    配置信息源:
    spring中实现了MessageSource接口的类可以配置信息源,常用的有ResourceBundleMessageSource
    和ReloadableResourceBundleMessageSource
    java代码:
    @Bean
    public MessageSource messageSource() {
      ReloadableResourceBundleMessageSource messageSource = 
          new ReloadableResourceBundleMessageSource();
    //ResourceBundleMessageSource messageSource = new ResourceBundleMessageSource();
      messageSource.setBasename("classpath:///messages");
      messageSource.setCacheSeconds(10);
      return messageSource;
    }
    
    创建URL
    <s:url>及<s:param>的用法见p229页
    
    转义内容
    <s:escapeBody>标签是一个通用的转义标签。它会渲染标签体中内嵌的内容, 并且在必要的时候进行转义:
    
    <s:escapeBody javaScriptEscape="true">
    <h1>Hello</h1>
    </s:escapeBody>
    
    <s:escapeBody htmlEscape="true">
    <h1>Hello</h1>
    </s:escapeBody>
    
    

二、使用Apache Tiles视图定义布局

  1. 配置
  2. 使用

三、使用Thymeleaf

  1. 配置
  • 在spring中配置三个bean:

    ThymeleafViewResolver:将逻辑视图名称解析为Thymeleaf模板视图;
    SpringTemplateEngine:处理模板并渲染结果;
    TemplateResolver:加载Thymeleaf模板。

  • java配置
    @Bean
    public ViewResolver viewResolver(SpringTemplateEngine templateEngine) {
      ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
      viewResolver.setTemplateEngine(templateEngine);
      return viewResolver;
    }
    @Bean
    public SpringTemplateEngine templateEngine(TemplateResolver templateResolver) {
      SpringTemplateEngine templateEngine = new SpringTemplateEngine();
      templateEngine.setTemplateResolver(templateResolver);
      return templateEngine;
    }
    @Bean
    public TemplateResolver templateResolver() {
      TemplateResolver templateResolver = new ServletContextTemplateResolver();
      templateResolver.setPrefix("/WEB-INF/views/");
      templateResolver.setSuffix(".html");
      templateResolver.setTemplateMode("HTML5");
      return templateResolver;
    }
    
  • xml配置
    xml配置Thymeleaf
  1. 使用
    略...见p240
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,242评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,769评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,484评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,133评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,007评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,080评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,496评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,190评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,464评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,549评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,330评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,205评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,567评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,889评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,160评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,475评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,650评论 2 335

推荐阅读更多精彩内容