跳到主要內容

JSP(7)_格式標籤庫


Formatting格式標籤庫

<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>


前綴已經設定為fmt
功能說明語法
fmt:formatNumber設定數字的格式<fmt:formatNumber value="" var=""/>
fmt:parseNumber設定字串的格式<fmt:parseNumber value="" var=""/>
fmt:formatDate設定日期格式<fmt:formatDate value="" var=""/>
fmt:parseDate設定字串的格式<fmt:parseDate value="" var=""/>
fmt:setLocale設定區域環境變數,參數部分參考i18n相關設定<fmt:setLocale value="" var=""/>
fmt:setBundle設定資料包的設定<fmt:setBundle value="" var=""/>
fmt:timeZone設定時間地區<fmt:timeZone value="" var=""/>
fmt:setTimeZone設定時間地區<fmt:setTimeZone value="" var=""/>
fmt:message設定輸出字串可以配合多國語言<fmt:message value="" var=""/>
fmt:requestEncoding使用多字元的編碼<fmt:requestEncoding value="" var=""/>
fmt:bundle設定資料包的設定<fmt:bundle value="" var=""/>


屬性說明:
(1)fmt:formatNumber
   會與核心標籤庫搭配使用,如果不熟請先參讀核心標籤庫(Core Tag)

屬性參數說明例子
value需要,數字內容值<c:set var="number" value="500.00"/>
<fmt:formatNumber value="${number}"/>
typeNUMBER(預設),、CURRENCY、 PERCENT參數使用<c:set var="number" value="500.00">
<fmt:formatNumber value="${number}" type="CURRENCY"/>
pattern數字格式客制化設定<fmt:formatNumber value="125.0000" pattern="NT: ###,###.000"/>
maxIntegerDigits最大整數位,超過會四捨五入<fmt:formatNumber value="125.0000" maxIntegerDigits="3" />
minIntegerDigits最小整數位
maxFractionDigits最大分數
minFractionDigits最小分數
scopepage|request|session|application<fmt:formatNumber var="newNumber" value="125.0000" scope="page" />
var賦予變數名稱<fmt:formatNumber var="newNumber" value="125.0000" />
groupingUsed不會做group number<fmt:formatNumber value="12500.000" groupingUsed="false" pattern="NT: ###,###.000" />
輸出: 12500.000

  • 樣式格式(pattern)
樣式敘述
0表示為一個數字
E表示exponential格式
#表示為一個數字,當有空缺已0去補滿
.為小數點
;分隔符號
-負數
%百分點
貨幣可以在前面加入字母來表示貨幣的值



(2)fmt:parseNumber
   會與核心標籤庫搭配使用,如果不熟請先參讀核心標籤庫(Core Tag)

屬性參數說明例子
value需要,數字內容值<c:set var="number" value="500.00"/>
<fmt:parseNumber  value="${number}" />
typeNUMBER(預設),、CURRENCY、 PERCENT參數使用<c:set var="number" value="500.00">
<fmt:parseNumber value="${number}" type="CURRENCY"/>
parseLocale區域設定
integerOnly是否只輸出整數部分預設為false<fmt:parseNumber var="newNumber" value="125.0000"  integerOnly="true" />
pattern客制化輸出<fmt:formatNumber value="125.0000" pattern="NT: ###,###.000"/>
timeZone輸出時間<fmt:parseNumber var="newNumber" value="125.0000"  />
var賦予變數名稱<fmt:parseNumber var="newNumber" value="125.0000" />
scope
page|request|session|application<fmt:parseNumber var="newNumber" value="125.0000" scope="page" />


(3)fmt:formatDate


屬性參數說明例子
value需要,日期內容值<c:set var="date" value=" new Date()"/>
<fmt:formatDate value="${date}" />
typeDATE(預設)、TIME、 BOTH使用<c:set var="date" value=" new Date()"/>
<fmt:formatDate value="${date}" type="DATE"/>
dateStyleFULL, LONG, MEDIUM, SHORT, or DEFAULT(預設)<c:set var="date" value="new Date()">
<fmt:formatDate value="${date}" type="DATE"/>
timeStyle是否只輸出整數部分預設為false<fmt:formatDate var="newNumber" value="125.0000"  integerOnly="true" />
pattern客制化輸出<fmt:formatDate value="125.0000" pattern="NT: ###,###.000"/>
timeZone輸出時間<fmt:formatDate var="newNumber" value="125.0000"  />
var賦予變數名稱<fmt:formatDate var="newNumber" value="125.0000" />
scope
page|request|session|application<fmt:formatDate var="newNumber" value="125.0000" scope="page" />



  • 樣式格式(pattern)
樣式敘述
y表示年
M
表示月
d表示日
h(12制)表示小時(12制)
H表示小時(24制)
m表示分
s表示秒
S表示毫秒(millisecond)
E
表示一星期的禮拜幾
a表示AM/PM
D表示一年中的第幾天

(4)fmt:parseDate


(5)fmt:setLocale
當我們要顯示國家的貨幣符號可以利用locale來完成,設定區域環境變數,參數部分參考i18n相關設定。 而下面例子我們美國為例:

====================程式片段=================================
<c:set var="money" value="500.00"/>
<fmt:setLocale value="en_US"/>
<fmt:formatNumber value="${money}" type="currency"/>

 輸出結果: $500.00

(6)fmt:timeZone 與 fmt:setTimeZone
    屬性: <fmt:timeZone value="地區參數" />


     <c:set var="day1" value="<%=new Date()%>"/>
    <fmt:setLocale value="zh_TW"/>
    <fmt:formatDate value="${day1}" timeStyle="long" dateStyle="long" />



(7)fmt:message
    通常作為

屬性參數說明例子
keykey值,通常將key設在properties中
bundle用於資源包定義key/value對,如果<fmt:bundle>有定義就不需用此標記
var字串變數名稱
scope
page|request|session|application

EX:多國語言的介面,我們可以利用fmt:bundle和fmt:message來完成

英文: app.properties
lastName=Last Name
firstName=First Name
personInfo=Personal Infomation
hobby=hobby
sport=sport
sport1=baseball
sport2=football
sport3=abadminton

中文: app_zh_TW.properties
lastName=\u59d3
firstName=\u540d
personInfo=\u500b\u4eba\u8868\u55ae
sport=\u904b\u52d5
sport1=\u68d2\u7403
sport2=\u8db3\u7403
sport3=\u7fbd\u7403
hobby=\u55dc\u597d

撰寫主畫面:main.jsp
<body>
  <c:url var="engURL" value="application.jsp">
  <c:param name="locale" value="en_US"/>

   </c:url>
   <a href="${engURL}" >English</a>
   <c:url var="chineseURL" value="application.jsp">
   <c:param name="locale" value="zh_TW" />

   </c:url>
    <a href="${chineseURL}" >chinese</a>
</body>


個人表單畫面:application.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"  pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<html>
<head>
<title>Insert title here</title>
</head>
 <c:set var="loc" value="en_US"/>
    <c:if test="${! empty (param.locale)}">
       <c:set var="loc" value="${param.locale}"/>
    </c:if>
   
    <fmt:setLocale value="${loc}"/>  
<body>
 <fmt:bundle basename="app">
 <table width="800" border="1px">
 <tr><td colspan="2" style="text-align:center"><h1><fmt:message key="personInfo"></fmt:message> </h1></td></tr>
 <tr><td style="text-align:center"> <fmt:message key="lastName" /></td><td style="text-align:left"> <input type="text"  name="lastName" value=""/></td>
 <tr><td style="text-align:center"><fmt:message key="firstName" /></td><td style="text-align:left"> <input type="text"  name="firstName" value=""/></td>
 <tr><td style="text-align:center"><fmt:message key="hobby" />    </td><td style="text-align:left"> <input type="text"  name="hobby" value=""/></td>
 <tr><td style="text-align:center"><fmt:message  key="sport" /></td>
 <td style="text-align:left"> 
  <fmt:message  key="sport1" /><input type="checkbox" value="sport" value="baseball">
  <fmt:message  key="sport2" /><input type="checkbox" value="sport" value="football">
   <fmt:message key="sport3" /><input type="checkbox" value="sport" value="abadminton">
 </td>
 </fmt:bundle> 
 <br>
 <tr><td colspan="2" style="text-align:center"><input type="submit" value="submit" /></td></tr>
 </table>
   <input type="hidden" name="locale" vaule="${loc}" ><br>
</body>
</html>



 
 

(8)fmt:requestEncoding
   <fmt:requestEncoding value="UTF-8" />

(9)fmt:bundle 與 fmt:setbundle
   <fmt:bundle basename="資料包位址" prefix="" />

   <fmt:setbudle basename="資料包位址" var=" " scope =" " />
 




















留言

這個網誌中的熱門文章

GSON基礎教學

GSON 前言 JSON是很常見的資料交換格式,在JAVA領域常用處理JSON的函式庫:GSON、FastXML和JSON-B,本章節會以GSON為主,學習目標如下 JSON格式說明 GSON 套件函式 GSON: 物件轉換JSON字串 GSON: JSON字串轉換物件 JSON 格式說明 JSON全名為JavaScript Object Notation,它是一種輕量級的資料交換格式,會大為流行的理由,主要是他比傳統用xml更輕巧且容易處理, JSON表達方式物件會用大括弧{},陣列則是用中括號[]。 用JSON字串來表達Employee的物件內容,由JSON字串可以知道物件name、age、sex和salary屬性。 JSON表示員工資料方式: {“name”:”Jack Bryant”, “age”:18, “sex”:”M”,”salary”:3500.00} JSON陣列表示方式: 跟我們使用JAVA的陣列方式類似,內容值可以是數字’、文字、布林、陣列、物件、null等等。 範例: 字串: [“紅”、”橙”、”黃”、”綠”、”青”、”藍”、”紫”} 布林: [true, true, false, false, true, true] GSON 套件函式 Gson為google所發布的函式庫,主要將物件與json字串之間的轉換時方便使用。當我們將JAVA物件轉換成JSON字串稱為 序列化 ,JSON字串轉換至JAVA物件稱為 反序列化 。 GSON: 物件轉換JSON字串 有了JSON基本概念後,我們進入本章重點,首先我們需要建立員工類別(Employee),定義如下 物件 屬性 員工類別 Employee name 名字 age 年紀 sex 性別 salary 薪水 /** * name:員工類別 */ public class Employee implements Serializable { //constructor public Employee(String name, double salary){ this.name = name; this.sala...

Python AI-問題集

Python AI-問題集 問題集 Jupyter Notebook執行ipywidgets會出現kernel死掉的錯誤發生(The kernel appears to have died) 解決方法 (1) 根據log檔來判斷問題: 例如:log訊息出現OMP: Error #15: Initializing libiomp5.dylib, but found libiomp5.dylib already initialized. (2) 根據問題關鍵字找出問題所在: 利用google查詢所遭遇到的問題,例如我把上面的問題上google查詢可以找到這篇的解法 https://blog.csdn.net/bingjianIT/article/details/86182096 (3)實作解法: 我實作下面解法後,就可以順利執行手寫辨識的程式. //在Python宣告時加入 import os os.environ["KMP_DUPLICATE_LIB_OK"]="TRUE" 參考 https://blog.csdn.net/bingjianIT/article/details/86182096

PHP與Python搭配

今天介紹如何利用php網頁呼叫目錄下的python程式工作或是資料交換,本人整理的方法有兩種 使用system()、exec()、shell_exec()呼叫程式 (1) string system ( string return_var ] ) 參考網址 官網解釋system()用來執行外部命令,返回為印出的結果,passthru()跟system()類似但是它不會返回結果。 範例1. 利用system執行ls指定並顯示在網頁上,無法使用變數保留ls的結果 檔案名稱: psystem.php $jsondata= system("ls -al", $result); 結果: (2) exec() : string exec ( string output [, int &$return_var ]] ) 參考網址 範例2. 利用exec執行python程式並可以回傳json格式給前端網頁做處理並顯示。我們ptopy.php就是可以看到callpy()為執行py的函式,它執行完pyEx01.py會將結果給$jsondata變數,做後面json解析。 檔案名稱: ptopy.php function callpy() { $jsondata= exec("/usr/bin/python pyEx01.py"); return $jsondata ; } $jsondata= callpy(); echo $jsondata ; echo " " ; $obj = json_decode($jsondata) ; echo "name:".$obj-> { 'name'} .',' ; echo "id:".$obj-> { 'id'} ; 檔案名稱: pyEx01.py import sys ...