`
zwt2001267
  • 浏览: 450586 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JSP页面中用JSTL和JavaScript格式化和解析日期

阅读更多

1. JSTL格式化和解析日期

格式化日期:

<fmt:formatDate value="${model.date}" pattern ="yyyy-MM-dd" > 

或者 

<fmt:formatDate value="<%=new java.util.Date() %>" pattern ="yyyy-MM-dd" /> 

取得request参数: 

<c:out value="param.参数名"/> 

jstl格式化日期标签收藏
<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jstl/fmt" %> 

<fmt:parseDate value="${param.date}" var="date" pattern="yyyy/MM/dd:HH:mm:ss>
<fmt:parseDate value="${param.isoDate}" var="isoDate" pattern="yyyyMMdd'T'HHmmss"> 

The input parameters must match the patterns, or the JSP will thrown an exception. This page does no error handling. 

Input parameters:
Date:    2004/04/01:13:30:00   Java format: Thu Apr 01 13:30:00 CST 2004
isoDate: 20040531T235959       Java format: Mon May 31 23:59:59 CDT 2004 

Dates
Tag Output 
Attribute: value; required. Tag has no body. 
<fmt:formatDate value="${date}" type="both"/> 

2004-4-1 13:30:00  
<fmt:formatDate value="${isoDate}" type="both"/> 

2004-5-31 23:59:59  
Attribute: type; optional. Indicates what to print: date, time, or both. 
<fmt:formatDate value="${date}" type="date"/> 

2004-4-1  
<fmt:formatDate value="${isoDate}" type="time"/> 

23:59:59  
Attribute: dateStyle; optional. Varies the date format. 
<fmt:formatDate value="${isoDate}" type="date" dateStyle="default"/> 

2004-5-31  
<fmt:formatDate value="${isoDate}" type="date" dateStyle="short"/> 

04-5-31  
<fmt:formatDate value="${isoDate}" type="date" dateStyle="medium"/> 

2004-5-31  
<fmt:formatDate value="${isoDate}" type="date" dateStyle="long"/> 

2004年5月31日  
<fmt:formatDate value="${isoDate}" type="date" dateStyle="full"/> 

2004年5月31日 星期一  
Attribute: timeStyle; optional. Varies the time format. 
<fmt:formatDate value="${isoDate}" type="time" timeStyle="default"/> 

23:59:59  
<fmt:formatDate value="${isoDate}" type="time" timeStyle="short"/> 

下午11:59  
<fmt:formatDate value="${isoDate}" type="time" timeStyle="medium"/> 

23:59:59  
<fmt:formatDate value="${isoDate}" type="time" timeStyle="long"/> 

下午11时59分59秒  
<fmt:formatDate value="${isoDate}" type="time" timeStyle="full"/> 

下午11时59分59秒 CDT  
Attribute: pattern; optional. Inidcates date/time custom patterns. 
<fmt:formatDate value="${date}" type="both" pattern="EEEE, MMMM d, yyyy HH:mm:ss Z"/> 

星期四, 四月 1, 2004 13:30:00 -0600  
<fmt:formatDate value="${isoDate}" type="both" pattern="d MMM yy, h:m:s a zzzz/> 

 

 

2. JavaScript 格式化

 

/**//*
  将String类型解析为Date类型.
  parseDate('2006-1-1') return new Date(2006,0,1)
  parseDate(' 2006-1-1 ') return new Date(2006,0,1)
  parseDate('2006-1-1 15:14:16') return new Date(2006,0,1,15,14,16)
  parseDate(' 2006-1-1 15:14:16 ') return new Date(2006,0,1,15,14,16);
  parseDate('2006-1-1 15:14:16.254') return new Date(2006,0,1,15,14,16,254)
  parseDate(' 2006-1-1 15:14:16.254 ') return new Date(2006,0,1,15,14,16,254)
  parseDate('不正确的格式') retrun null
*/
function parseDate(str){
  if(typeof str == 'string'){
    var results = str.match(/^ *(\d{4})-(\d{1,2})-(\d{1,2}) *$/);
    if(results && results.length>3)
      return new Date(parseInt(results[1]),parseInt(results[2]) -1,parseInt(results[3])); 
    results = str.match(/^ *(\d{4})-(\d{1,2})-(\d{1,2}) +(\d{1,2}):(\d{1,2}):(\d{1,2}) *$/);
    if(results && results.length>6)
      return new Date(parseInt(results[1]),parseInt(results[2]) -1,parseInt(results[3]),parseInt(results[4]),parseInt(results[5]),parseInt(results[6])); 
    results = str.match(/^ *(\d{4})-(\d{1,2})-(\d{1,2}) +(\d{1,2}):(\d{1,2}):(\d{1,2})\.(\d{1,9}) *$/);
    if(results && results.length>7)
      return new Date(parseInt(results[1]),parseInt(results[2]) -1,parseInt(results[3]),parseInt(results[4]),parseInt(results[5]),parseInt(results[6]),parseInt(results[7])); 
  }
  return null;
} 

/**//*
  将Date/String类型,解析为String类型.
  传入String类型,则先解析为Date类型
  不正确的Date,返回 ''
  如果时间部分为0,则忽略,只返回日期部分.
*/
function formatDate(v){
  if(typeof v == 'string') v = parseDate(v);
  if(v instanceof Date){
    var y = v.getFullYear();
    var m = v.getMonth() + 1;
    var d = v.getDate();
    var h = v.getHours();
    var i = v.getMinutes();
    var s = v.getSeconds();
    var ms = v.getMilliseconds();   
    if(ms>0) return y + '-' + m + '-' + d + ' ' + h + ':' + i + ':' + s + '.' + ms;
    if(h>0 || i>0 || s>0) return y + '-' + m + '-' + d + ' ' + h + ':' + i + ':' + s;
    return y + '-' + m + '-' + d;
  }
  return '';
}

 

分享到:
评论

相关推荐

    Auction(JSP中用Js进行dom操作ajax静态刷新案例代码).rar

    EL用于在JSP页面中直接表达Java变量,而JSTL提供了各种标签库,如core、fmt、sql等,用于执行常见任务,如条件判断、循环、日期格式化和数据库操作。 在压缩包中的"Auction"文件,可能包含了JSP文件、JavaScript...

    在JSP页面用JS处理从服务器返回的LIST集合

    总之,在JSP页面中用JavaScript处理服务器返回的LIST集合涉及多个步骤,包括数据的序列化、传输、解析以及在客户端渲染。理解这些知识点对于开发响应式、交互性强的Web应用至关重要。通过熟练掌握这些技能,开发者...

    一个jsp blog网站开发

    例如,`&lt;c:forEach&gt;`遍历集合,`&lt;fmt:formatDate&gt;`格式化日期。 9. CSS与JavaScript:前端展示通常结合HTML、CSS和JavaScript实现。CSS用于样式设计,JavaScript用于实现页面交互,如表单验证、动态加载等。JSP可...

    JSP-Servlet-Ajax考题共享

    - JSTL(JavaServer Pages Standard Tag Library)是标准标签库,包括核心、XML、格式化等标签集。 - EL与JSTL协同工作,简化JSP页面,提高可读性。 12. **Servlet基础**: - Servlet是Java实现的服务器端组件,...

    打印报表调用后台servlet出库数据-项目

    这种类型的项目通常会涉及数据库操作、数据查询、数据格式化和报表生成等技术。 标签 "源码" 暗示我们可能会看到具体的Java代码示例,可能是Servlet的实现代码,或者是JSP中用于发送请求和接收响应的部分。"工具...

    Javaweb判断题.rar

    5. **JSTL(JavaServer Pages Standard Tag Library)**:JSTL是一组用于JSP页面的标准标签库,提供更简洁、可读性强的代码,替代自定义脚本动作,例如条件语句、迭代、XML处理等。 6. **Filter和Servlet Chain**:...

    相关的jar包一键下载

    它包含了许多为创建图表和图形界面时常用到的组件和工具,这些工具在数据可视化和报告生成中非常有用。该库是由jfreechart的开发者维护的,因此和jfreechart库有着很好的兼容性。 jdk-8u181-windows-x64是Java开发...

    画板的设计

    2. **JSP和JSTL**:可能使用JSP(JavaServer Pages)来简化视图层的开发,JSTL(JavaServer Pages Standard Tag Library)可以提高JSP的可维护性和可读性。 3. **前端技术**:HTML、CSS和JavaScript,用于构建用户...

    云网论坛CWBBS 2.4 RC (eclipse工程)(毕设 + 课设).zip

    6. **Web应用程序开发**:云网论坛CWBBS 2.4 RC作为一个Web应用,可能会涉及Servlets、JSP、JSTL等技术,用于处理用户请求和展示动态内容。同时,可能会使用数据库(如MySQL、Oracle)存储用户信息、帖子数据等。 7...

    freemarker总结

    options:该参数可以省略,指定包含时的选项,包含encoding和parse两个选项,其中encoding指定包含页面时所用的解码集,而parse指定被包含文件是否作为FTL文件来解析,如果省略了parse选项值,则该选项默认是true. ...

Global site tag (gtag.js) - Google Analytics