在JSTL标准标签库中,<fmt:setLocale>标签的value值,代表了某区域的语系和地区码,相当于一个地域文化的ID,java的官方文档解释为:
A String value is interpreted as the printable representation of a locale, which must contain a two-letter (lower-case) language code (as defined by ISO-639), and may contain a two-letter (upper-case) country code (as defined by ISO-3166). Language and country codes must be separated by hyphen (-) or underscore (_).
直译:该值是一个字符串类型的值,是可供打印输出的某个区域的标识(个人理解为ID)。该标识由一个语系代码(两个小写字母组成,根据ISO-639标准)和一个地区码(两个大写字母组成,根据ISO-3166标准)组成。语系代码和地区码之间必须用连字符“-”或下划线“_”隔开。
可见区域ID的结构为【mm_NN】或【mm-NN】。遍历该ID的jsp页面源码如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" import="java.util.Locale"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>setLocale Values</title>
</head>
<body>
<%
Locale[] localeList= Locale.getAvailableLocales();
pageContext.setAttribute("list", localeList);
%>
<table border="1" cellspacing="0" cellpadding="8">
<caption><h3>可用作<fmt:setLocale>标签的value值汇总</h3></caption>
<tr align="center">
<th>语 系</th><th>国家和地区</th><th>value值</th><th>货币格式(987654321.0123456789)</th>
</tr>
<c:forEach var="locale" items="${list}">
<!-- 1、设置区域为当前循环中的区域 -->
<fmt:setLocale value="${locale}"/>
<!-- 2、筛选显示内容 -->
<c:set var="flag" value="true"/>
<c:if test="${empty locale.country}">
<c:set var="flag" value="false"/>
</c:if>
<!-- 3、选择性输出结果 -->
<c:if test="${flag eq true}">
<tr align="center">
<td>${locale.displayLanguage}</td>
<td>${locale.displayCountry}</td>
<td>${locale.language}_${locale.country}</td>
<td>
<fmt:formatNumber type="currency" value="987654321.0123456789"/>
</td>
</tr>
</c:if>
</c:forEach>
</table>
</body>
</html>
运行结果:
经测试,得到的value值既可以用作<fmt:setLocale>的value的值,也可以在<fmt:parseNumber>解析字符串类型的货币数据时,通过指定对应的地域ID来简化解析代码。如:
<body>
<c:set var="demo1" value="123456.01234" />
<h4>初始值demo1 = <c:out value="${demo1}"/></h4>
<p>
示例1:格式化处理:设置文化地域为en_US,按货币类型显示:
<fmt:setLocale value="en_US" />
<fmt:formatNumber type="currency" value="${demo1}"/>
</p>
<c:set var="demo2" value="NT$25.00" />
<h4>初始值demo2 = <c:out value="${demo2}"/></h4>
<p>
<fmt:parseNumber var="demo3" type="currency" value="${demo2}" parseLocale="zh-TW"/>
示例2:将“NT$25.00”按新台币解析为数字类型的结果为:<c:out value="${demo3}" />
</p>
</body>
运行结果(其中$是系统根据设置的区域自动生成的):
初始值demo1 = 123456.01234
示例1:格式化处理:设置文化地域为en_US,按货币类型显示: $123,456.01
初始值demo2 = NT$25.00
示例2:将“NT$25.00”按新台币解析为数字类型的结果为:25