<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Sky's blog

    我和我追逐的夢

    常用鏈接

    統(tǒng)計

    其他鏈接

    友情鏈接

    最新評論

    WebWork中格式化輸出數(shù)字和日期的方法

        前言:大概在去年6月的時候,我們團隊開始使用webwork來替代struts,剛開始大家都沒有經(jīng)驗,為了格式化輸出時間和數(shù)字,想出了很多現(xiàn)在看來笨笨的傻傻的方法。后來俺找到了這個方法,試驗了一下之后發(fā)了下面這個email給了team member, 今天一位同事問起這個問題,俺從數(shù)以千計的已發(fā)送郵件中找到了這個東西,想想決定整理出來。給大家分享一下,順便給我自己做個備份,呵呵,后者基本上是俺寫blog的一個重要用途。

        分享一個在WebWork中如何格式化顯示數(shù)字和日期的方法:


    具體的做法這里有詳細(xì)的說明:
    http://wiki.opensymphony.com/display/WW1/How+to+format+dates+and+numbers?showComments=true


       下面是項目中推薦使用的時間格式:
    #format
    global.format.date={0,date,yyyy-MM-dd}
    global.format.time={0,date,HH:mm:ss}
    global.format.datetime={0,date,yyyy-MM-dd HH:mm:ss}

    注意的是如果使用Carlender來保存時間,因為上面要求傳入的是Data對象,因此需要使用Carlender.getTime()方法
    從Carlender中獲取Date:

    <ww:text name="'global.format.date'">
        <ww:param value="'birthday.time()'"/>
    </ww:text>

    這里使用的是<ww:param/>標(biāo)簽來傳遞參數(shù),雖然也可以使用 <ww:text name="'format.date'" value0= "'birthday.time()'"/>
    但是后面的這個方法在webwork的新版本中已經(jīng)被要求不要使用,大家還是盡量使用 <ww:param/>標(biāo)簽

    禁用value0屬性的說明:
    大家可以找到text標(biāo)簽的源代碼,在com.opensymphony.webwork.views.jsp.ui.TextTag中:
    public void setValue0(String aName) {
            LOG.warn("The value attributes of TextTag are deprecated.");
            value1Attr = aName;
        }

     


    對于數(shù)字的格式化,這里有兩個參考:
    global.format.percent = {0,number,##0.00'%'}
    global.format.money = {0,number,$##0.00}

    考慮目前在項目中使用最多的是顯示附件大小,定義以下格式:
    global.format.size.k={0,number,##0.00'K'}
    global.format.size.m={0,number,##0.00'M'}
    global.format.size.g={0,number,##0.00'G'}

    如action有方法
    public long getFilesize();  返回的大小是以byte為單位,在顯示時通常是以k或M顯示
    則顯示時:
    <ww:text name="'global.format.size.k'">
        <ww:param value="filesize/1024"/>
    </ww:text>
    <ww:text name="'global.format.size.m'">
        <ww:param value="filesize/1048576"/>
    </ww:text>
    <ww:text name="'global.format.size.g'">
        <ww:param value="filesize/1073741824"/>
    </ww:text>

    比較遺憾的是似乎沒有辦法在資源文件中進行這個/1024的運算,試過{0/1024,number,##0.00'K'} 無法解析。只好在jsp里面用 value="filesize/1024"來計算實際值。不知道這里有沒有別的更好的實現(xiàn)方式?

    恩,順便再介紹一下當(dāng)時俺們team想出來的笨笨的方法,不要見笑啊,以上面的顯示文件大小為例,想到的方法大致有以下幾種:
    1. 直接輸出字符串的結(jié)果
       getFileSizeString(), 在里面用java代碼判斷大小并生成諸如"1.2k", "31.2M"的結(jié)果返回
    2. 提供多個函數(shù)
      getFileSizeByte(), getFileSizeK(), getFileSizeM(), getFileSizeG()
    3.使用javascript在client端格式化
          <script type = "text/javascript">     
          var resultNum = <ww:property value="fileSize" />;
           resultNum = format(resultNum);//類似的函數(shù)  
          document.write(resultNum);
         </script>
    4.使用自定義標(biāo)簽

    posted on 2006-08-14 13:41 sky ao 閱讀(4708) 評論(4)  編輯  收藏 所屬分類: web

    評論

    # re: WebWork中格式化輸出數(shù)字和日期的方法 2006-08-14 14:10 夢秋雨

    可以采用out.printf或者String.format()來格式化。

    當(dāng)然了,要在J2SE5.0上.  回復(fù)  更多評論   

    # re: WebWork中格式化輸出數(shù)字和日期的方法 2006-08-14 17:31 飄然

    哦? 我說的是在jsp頁面上做格式化哦,“out.printf或者String.format()”像是寫java代碼。不適合用在jsp頁面吧?  回復(fù)  更多評論   

    # re: WebWork中格式化輸出數(shù)字和日期的方法 2006-08-15 09:06 夢秋雨

    嗯,我想的是后端格式化然后到前端輸出。

    我以前也曾遇到過這個問題,寫了一個統(tǒng)一的js,在頁面上處理,和你的方法差不多了。  回復(fù)  更多評論   

    # re: WebWork中格式化輸出數(shù)字和日期的方法 2009-01-24 17:40 IT公司面試手冊

    我們是用freemarker的宏做的  回復(fù)  更多評論   

    主站蜘蛛池模板: 国产高清在线免费视频| 久久A级毛片免费观看| 美女黄网站人色视频免费国产 | 亚洲国产成人影院播放| 亚洲日韩一区二区一无码| 99re热免费精品视频观看| 亚洲av成人综合网| 成人毛片免费观看视频在线| 亚洲日韩一区二区三区| 国产又黄又爽又刺激的免费网址| www亚洲精品久久久乳| 亚洲av高清在线观看一区二区| 最好2018中文免费视频| 中文字幕亚洲天堂| 中文字幕无码免费久久| 亚洲va久久久噜噜噜久久天堂| 桃子视频在线观看高清免费视频| 亚洲美女色在线欧洲美女| 久久福利资源网站免费看| 国产成人精品日本亚洲专一区| 在线观看免费精品国产| 四虎影视久久久免费观看| 皇色在线免费视频| 亚洲综合日韩久久成人AV| 色猫咪免费人成网站在线观看| 久久久久亚洲精品无码蜜桃| 大学生一级特黄的免费大片视频| 国产精品无码亚洲一区二区三区| 在线观看亚洲av每日更新 | 成年在线观看网站免费| 国产精品观看在线亚洲人成网| 亚洲天堂在线视频| 99热这里只有精品6免费| 亚洲熟妇无码八V在线播放 | 久久亚洲一区二区| 毛片A级毛片免费播放| 免费无毒a网站在线观看| 91亚洲精品麻豆| 四虎影视永久免费观看地址| 久久精品视频免费播放| 亚洲av无码无线在线观看|