`
newleague
  • 浏览: 1492144 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

Struts2自定义Theme

阅读更多

1. Struts2 Theme与WebWork Theme
     用法上是一样的,几乎没有差别,默认都是xhtm,区别就是将WebWork的配置改成了Struts的配置

2. Theme的作用
     Theme可以理解为模版,struts ui标签都有与之对应的模版,可以解压struts2-all-2.0.1.jar来看看,里面有template目录,打开xhtm查看struts ui标签对应的模版。我认为theme的作用如下:
    1) 统一考虑控件的外观和行为。例如对于文本框,有必填和非必填的,那么我们可以定制必填文本框的模版,在文本框后面带上红色的"*",并且带required校验。
    2) 统一的布局风格,我们只关注内容而不必关注布局。例如对form,一个应用中有多个查询界面,所有的查询界面都采用同样的form模版,保持统一的风格。

3. 定制Theme
   1) 在WEB-INF下建立文件夹themes/mytheme
   2) 配置struts.properties,指定使用的theme
           struts.ui.theme = mytheme
           struts.ui.templateDir = /WEB-INF/themes
   3) text.ftl
   普通文本框

<input type="text"<#rt/>
 name="${parameters.name?default("")?html}"<#rt/>
<#if parameters.get("size")?exists>
 size="${parameters.get("size")?html}"<#rt/>
</#if>
<#if parameters.maxlength?exists>
 maxlength="${parameters.maxlength?html}"<#rt/>
</#if>
<#if parameters.nameValue?exists>
 value="<@s.property value="parameters.nameValue"/>"<#rt/>
</#if>
<#if parameters.disabled?default(false)>
 disabled="disabled"<#rt/>
</#if>
<#if parameters.readonly?default(false)>
 readonly="readonly"<#rt/>
</#if>
<#if parameters.tabindex?exists>
 tabindex="${parameters.tabindex?html}"<#rt/>
</#if>
<#if parameters.id?exists>
 id="${parameters.id?html}"<#rt/>
</#if>
<#if parameters.cssClass?exists>
 class="${parameters.cssClass?html}"<#rt/>
</#if>
<#if parameters.cssStyle?exists>
 style="${parameters.cssStyle?html}"<#rt/>
</#if>
<#if parameters.title?exists>
 title="${parameters.title?html}"<#rt/>
</#if>
/>
required text

<input type="text"<#rt/>
 name="${parameters.name?default("")?html}"<#rt/>
<#if parameters.get("size")?exists>
 size="${parameters.get("size")?html}"<#rt/>
</#if>
<#if parameters.maxlength?exists>
 maxlength="${parameters.maxlength?html}"<#rt/>
</#if>
<#if parameters.nameValue?exists>
 value="<@s.property value="parameters.nameValue"/>"<#rt/>
</#if>
<#if parameters.disabled?default(false)>
 disabled="disabled"<#rt/>
</#if>
<#if parameters.readonly?default(false)>
 readonly="readonly"<#rt/>
</#if>
<#if parameters.tabindex?exists>
 tabindex="${parameters.tabindex?html}"<#rt/>
</#if>
<#if parameters.id?exists>
 id="${parameters.id?html}"<#rt/>
</#if>
<#if parameters.cssClass?exists>
 class="${parameters.cssClass?html}"<#rt/>
</#if>
<#if parameters.cssStyle?exists>
 style="${parameters.cssStyle?html}"<#rt/>
</#if>
<#if parameters.title?exists>
 title="${parameters.title?html}"<#rt/>
</#if>
/>
<span style="color:red">*</span>

下面的一行使用requiredtext模版
<s:textfield label="%{getText('username')}" name="username" template="requiredtext.ftl"/>

参考:http://www.jscud.com/srun/news/viewhtml/4_2006_3/182.htm

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/cydooo/archive/2007/01/07/1476026.aspx

分享到:
评论

相关推荐

    struts2自定义标签

    Struts2自定义标签是开发Web应用时为了增强框架功能、提高代码复用性和可维护性而创建的自定义HTML标签。这些标签可以扩展Struts2内置的标签库,以满足特定项目的需求。在本例中,我们关注的是实现一个自定义的分页...

    Struts2_自定义标签的方法

    ### Struts2自定义标签详解 #### 一、引言 在Web开发中,Struts2框架因其灵活性和强大的功能而被广泛采用。其中,自定义标签是提高代码复用性和增强页面展示效果的重要手段。本文将深入探讨如何在Struts2中创建...

    struts2 theme主题

    Struts2中的主题功能主要由`org.apache.struts2.views.theme.Theme`类提供,它定义了一系列的模板和CSS样式。默认情况下,Struts2提供了多个内置主题,如"simple", "xhtml", "ajax", "css_xhtml"等,每个主题都有其...

    Struts2源码分析

    Struts2提供了一系列增强的组件,位于`org.apache.struts2.components`包中,包括updownselect、doubleselect、datetimepicker、token、tree等,这些组件增强了用户体验,并且支持主题(theme)以自定义页面样式。...

    Struts2属性文件详解

    指定了Struts 2应用加载的用户自定义属性文件,自定义属性文件中的设置不会覆盖`struts.properties`文件中的配置。如果需要加载多个自定义属性文件,可以使用英文逗号`,`分隔文件名。 #### struts.mapper.class 该...

    Struts2中的validation_多国语言版 国际化i18n+struts2数据校验.zip

    另外,`struts2 theme主题就是外观样式.txt`提到了Struts2的主题和外观。Struts2允许自定义视图的呈现方式,包括错误消息的显示样式。通过修改或创建主题,我们可以控制错误信息的CSS样式,如`errorMessage格式样式...

    Struts2工作机制

    Struts2提供了丰富的视图组件,如`updownselect`、`doubleselect`、`datetimepicker`等,这些组件可以通过主题(theme)定制样式,使得视图的外观更加统一和美观。 总的来说,Struts2的工作流程大致为:请求到达-&gt;...

    struts2.0整合Struts 1

    2. **拦截器(Interceptor)**:这是Struts 2的一大亮点,它们是可插拔的组件,可以在Action调用前后执行自定义逻辑,如日志、权限检查等,增强了框架的灵活性。 3. **OGNL(Object-Graph Navigation Language)**...

    struts2错误显示

    对于上述两种默认的显示方式,可能并不满足所有应用场景的需求,例如需要将错误信息显示在字段之后,且保持在同一行内,这时就需要对Struts2的错误信息显示格式进行自定义。 ##### 自定义步骤: 1. **定制CSS样式**...

    struts2 标签 tags API 参考文档

    Struts2是一个强大的MVC框架,它在Java Web开发中占据着重要的地位。WebWork2是Struts2的前身,其思想和设计被融入到Struts2中,为开发者提供了丰富的功能和便捷的API。本参考文档主要关注的是Struts2中的标签(Tags...

    struts2 笔记(根据尚硅谷视频所记)

    `struts.ui.theme`定义了应用的主题,默认主题是`simple`,可以改变视图的展示风格。`struts.action.extension`配置了Struts2可接受的请求扩展名,默认为`.action`,在这里被扩展为包括`.do`和无扩展名的情况。 `...

    Struts2的工作机制及分析

    在处理请求的过程中,Struts2使用了拦截器(Interceptor)机制,拦截器是Struts2的一大特色,它们允许开发者插入自定义的行为,如权限检查、日志记录等。Struts2内置了一些常用的拦截器,如ValidationInterceptor...

    struts2工作原理

    1. `org.apache.struts2.components` 包:这个包包含了视图组件,Struts2在视图层做了大量的加强,添加了诸如updownselect、doubleselect、datetimepicker等新组件,并支持主题(theme)机制,允许开发者自定义页面...

    struts2配置文件详细说明

    - `struts.configuration`可以自定义配置管理器,实现`Configuration`接口来加载和管理Struts2配置文件。 这些配置选项只是Struts2配置文件中的一部分,实际上还有更多关于动作、拦截器、结果类型、包等的配置。...

    struts2标签详解与实例

    Struts2的主题标签允许开发者自定义视图的外观和风格。例如,使用`&lt;s:head&gt;`标签引入CSS和JavaScript资源,`&lt;s:fielderror&gt;`显示字段验证错误,`&lt;s:messages&gt;`展示全局消息。 四、实例解析 以下是一个简单的用户...

    struts2-jquery-plugin使用手册,自己写的

    - Struts2-jQuery-Plugin允许开发者选择不同的jQuery UI主题,通过`theme`属性设置,改变应用的视觉风格。 - 同时,它还支持国际化,可以轻松地切换语言环境,满足多语言应用的需求。 7. **实用特性** - `...

Global site tag (gtag.js) - Google Analytics