fmt标签个人用的比较少,但是我还是在这里简单的留一下笔记,也是算是学习了一下!这样方便你们课设的时候能用的上,要学会进步的学习,不要停留!

  引入该标签库的方法为:  

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

  这里提供了很多的内容,我这里只是介绍关于数字和日期格式化的内容

  formatNumber标签、formatData标签、parseNumber标签、parseDate标签、timeZone标签、setTimeZone标签

  1.<frm:formatNumber/>标签

  该标签依据特定的区域将数字改变为不同的格式来显示。

  

【语法1】:
<frm:formatNumber value=”被格式化的数”
[type=”number|currency|percent”]
[pattern=”pattern”]
[currencyCode=”code”]
[currencySymbol=”symbol”]
[groupingUsed=”true|false”]
[maxIntergerDigits=”maxDigits”]
[minIntergerDigits=”minDigits”]
[maxFractionDigits=”maxDigits”]
[minFractionDigits=”minDigits”]
[var=”name”]
[scope=page|request|session|application]
/>
还有一种是对标签哟!

1.<fmt:formatNumber>标签参数说明:

名称 类型 EL 类型 必须 默认值
value 要格式化的数据 String
type 指定类型(单位、货币、百分比等)见附表A 是  String number
pattern 格式化的数据样式 String
currencyCode 货币单位代码 String
cuttencySymbol 货币符号($、¥) String
groupingUsed 是否对整数部分进行分组如(9,999) boolean true
maxIntergerDigits 整数部分最对显示多少位数 int
minIntergerDigits 整数部分最少显示多少位 int
maxFractionDigits 小数部分最多显示多少位 int
minFractionDigits 小数部分最少显示多少位 int
var 存储格式化后的数据 String
scope var的JSP范围 String page

附表A,关于type的属性值介绍

类型 说明 示例
number 数字格式 0.8
currency 当地货币 ¥0.80
percent 百分比格式 80%

什么东西,都需要代码才能看到真相,所以喽,我们写一下代码,

LOOK:实现了对数字的格式化、货币的格式、货币的格式化。使用<frm:formatNumber>的各种属性的设定。

<table border=1 cellpadding="0" cellspacing="0" align="center">
<tr align="center">
<td width="100">类型</td>
<td width="100">使用数据</td>
<td width="100">结果</td>
<td width="300">说明</td>
</tr>
<tr>
<td>数字格式化</td>
<td>108.75</td>
<td>
<fmt:formatNumber type="number" pattern="###.#">108.75</fmt:formatNumber>
</td>
<td>
使用pattern可以定义显示的样式。本例设定为###.#小数部分将使用四舍五入法。
</td>
</tr>
<tr> <td>数字格式化</td>
<td>9557</td>
<td>
<fmt:formatNumber type="number" pattern="#.####E0">9557</fmt:formatNumber>
</td>
<td>
使用科学计数法。
</td>
</tr>
<tr>
<td>数字格式化</td>
<td>9557</td>
<td>
<fmt:formatNumber type="number">9557</fmt:formatNumber>
</td>
<td>
使用默认分组。
</td>
</tr> <tr>
<td>数字格式化</td>
<td>9557</td>
<td>
<fmt:formatNumber type="number" groupingUsed="false">9557</fmt:formatNumber>
</td>
<td>
不使用分组。
</td>
</tr>
<tr>
<td>数字格式化</td>
<td>9557</td>
<td>
<fmt:formatNumber type="number" maxIntegerDigits="3">9557</fmt:formatNumber>
</td>
<td>
使用位数限定,根据指定的位数显示,其他数字忽略。例如:9不被显示。
</td>
</tr>
<tr>
<td>百分比格式化</td>
<td>0.98</td>
<td>
<fmt:formatNumber type="percent">0.98</fmt:formatNumber>
</td>
<td>
用百分比形式显示一个数据。
</td>
</tr>
<tr>
<td>货币格式化</td>
<td>188.88</td>
<td>
<fmt:formatNumber type="currency">188.8</fmt:formatNumber>
</td>
<td>
将一个数据转化为货币形式输出。
</td>
</tr> <tr>
<td>存储数据</td>
<td>188.88</td>
<td>
<fmt:formatNumber type="currency" var="money">188.8</fmt:formatNumber>
${money}
</td>
<td>
存储的money的值为${money}
</td>
</tr>
</table>
<%--
(1)从应用角度可以把属性分为三类:数字格式化、货币格式化、百分比格式化。使用type指定类型。
(2)应用于数字格式化的属性有:partten属性、maxIntegerDigits属性、minIntegerDigits属性、maxFractionDigits属性和minFactionDigits属性。其中partten属性在设定格式化样式时会比较准确如:四舍五入、科学计数法的使用。而使用maIntegerDirgits等属性时,只把设定位数以外的数字舍去。
(3)货币格式化可以使用数字格式化的所有属性。如果有必要建议使用partten属性。currencyCode属性和currencySymbol只用于货币格式化。
(4)百分比格式化使用到的属性为type属性、partten属性,设定type属性的类型为percent即可。
(5)使用var属性时,会将格式化后的值存在JSP的某个范围内(一个String类型的字符串包括符号等)。<frm:forNumber>将不再输出格式化后的值可以使用EL表达式输出。
(6)通用属性:type属性、partten属性、var属性和scope属性。
--%>

2.<frm:parseNumber>标签

将格式化后的数字、货币、百分比都转化为数字类型。
【语法1】:
<fmt:parseNumber value="number"
[type=”number|currency|percent”]
[pattern=”pattern”]
[parseLocale=”locale”]
[intergerOnly=”true|false”]
[scope=”page|request|session|application”]
/>
还有一种是对标签哟!
还有一种是对标签哟!

<fmt:parseNumber>标签参数说明:

名称 说明 EL 类型 必须 默认
value 被解析的字符串 String
type 指定单位(数字、货币、百分比) String number
pattern 格式样式 String
parseLocale 用来替代默认区域的设定 StString/java.util.Locale 默认本地样式
var 存储已经格式化的数据 String
scope var变量的作用域 String page

<fmt:parseNumber>可以看作是<fmt:formatNumber>的逆运算。相应的参数和类型的配置和使用<fmt:formatNumber>格式化时相同。

【示例代码】:实现了从字符串中提取数据,并用合适的数据类型进行存储(浮点性、整型等)。可以对转换后的数据进行加法运算

<!-- 准备的数据为 -->
<fmt:formatNumber type="currency" var="money">188.8</fmt:formatNumber>
<ul>
<li>
格式化后的数据为:${money}
</li>
<fmt:parseNumber var="money" type="currency">${money}</fmt:parseNumber>
<li>
解析格式化后的数据为:${money}
</li>
<li>
解析可以对格式化的后的数据进行运算:${money+200}
</li>
<li>
解析对百分比进行格式化98%为:
<fmt:parseNumber type="percent">98%</fmt:parseNumber>
</li>
</ul>
<%--
(1)首先使用<fmt:formatNumber>将188.8转换为字符串¥188.8并在page范围内存储一个String类型的变量,变量名为money。
(2)使用<fmt:parseNumber>将¥188.8转化为浮点型的数据188.8并赋值为变量money,则变量money转变为一个浮点型的值188.8,对188.8进行加运算。
(3)直接对一个百分比数98%进行转化。
--%>

3.<fmt:formatDate>标签:该标签主要用来格式化日期和时间

【语法】:

<fmt:formatDate value=”date”
[type=”time|date|both”]
[pattern=”pattern”]
[dateStyle=”default|short|medium|long|full”]
[timeStyle=”default|short|medium|long|full”]
[timeZone=”timeZone”]
[var=”name”]
[scope=”page|request|session|application”]
/>

<fmt:formatDate>标签属性说明:

属性名 说明 EL 类型 必须 默认值
value 将要格式化的日期对象 Java.util.Date
type 显示的部分(日期、时间或者两者)附录表B String date
partten 格式化的样式。 String
dateStyle 设定日期的显示方式 String default
timeStyle 设定时间的显示方式 String default
timeZone 设定使用的时区 String 当地所用时区
var 存储已格式化的日期或时间 String
scope 指定var存储的JSP范围 String

附录表B:type属性参数说明:

参数名 说明
time 只显示时间
date 只显示日期
both 显示日期和时间

【示例程序】:实现了对日期的格式化,使用了type、dateStyle、timeStyle等属性。

<%
pageContext.setAttribute("date",new Date());
%> <fmt:formatDate value="${date}"></fmt:formatDate>
<br> <fmt:formatDate value="${date}" type="both"></fmt:formatDate>
<br> <fmt:formatDate value="${date}" type="both" dateStyle="default"
timeStyle="default"></fmt:formatDate>
<br> <fmt:formatDate value="${date}" type="both" dateStyle="short"
timeStyle="short"></fmt:formatDate>
<br> <fmt:formatDate value="${date}" type="both" dateStyle="long"
timeStyle="long"></fmt:formatDate>
<br> <fmt:formatDate value="${date}" type="both" dateStyle="full"
timeStyle="full"></fmt:formatDate>
<br> <fmt:formatDate value="${date}" type="both" dateStyle="full"
timeStyle="full"></fmt:formatDate>
<br>
<%--
1)对日期对象进行格式化时${date}是一个日期对象,如果给value设的值为String时程序会报错。 2)设置type为both时,将显示日期和时间,同时示例中依次改变dateStyle和timeStyle的值作为比较。
--%>

4.<fmt:parseDate>标签:<fmt:parseDate>标签主要将字符串类型的时间或日期转化为时间或日期对象

<fmt:parseDate
[type=”time|date|both”]
[pattern=”pattern”]
[parseLocale=”locale”]
[dateStyle=”default|short|medium|long|full”]
[timeStyle=”default|short|medium|long|full”]
[timeZone=”timezone”]
[var=”name”]
[scope=”page|request|session|application”]
>
Date
</fmt:parseDate>

<fmt:parseData>标签属性说明:

属性名 说明 EL 类型 必须 默认值
value 将要格式化的日期时间 String
type 字符串的类型(日期、时间或全部) String date
pattern 字符串使用的时间样式 String
parseLocale 取代默认地区设定 String 默认地区
dateStyle 字符串使用的日期显示方式 String default
timeStyle 字符串使用的时间显示格式 String default
timeZone 使用的时区 String 当地区时
var 使用var定义的名字保存对象 String
scope var的JSP范围 String page

【示例代码】:实现了以下功能:

  首先,使用了<fmt:formatDate>把一个日期对象格式化成一个日期的字符串,并把该字符串以参数名为a存储page范围内。

  其次,使用<fmt:parseDate>方法把a的值(字符串)格式化成一个Date并以参数名为b存储在page范围内。

  最后,使用Java脚本证明生成的b为对象。

<%
pageContext.setAttribute("date", new Date());
%> <fmt:formatDate value="${date}" var="a" type="both" dateStyle="full"
timeStyle="full"></fmt:formatDate> <fmt:parseDate var="b" type="both" dateStyle="full" timeStyle="full">
${a}
</fmt:parseDate>
<%
out.println(pageContext.getAttribute("b").toString());
out.println("<br>");
out.println(pageContext.getAttribute("b").hashCode());
%>
<%-- (1)使用<fmt:formatDate>把日期对象格式化成字符串。
(2)使用<fmt:parseDate>把字符串对象转化为日期对象,注意同(1)中的参数对比,可以发现两者是一个互逆的过程。
(3)使用Java脚本进行测试Date对象的toString()方法可以输出时间字符串。hashCode()可以得到一个对象的hashCode。该方法只能应用于对象,因此可以证明得到的是一个日期对象。
--%>

[应用篇]第五篇 JSTL之fmt标签日期和数字格式化的更多相关文章

  1. JSTL中fmt标签详解

    一:JSTL格式化标签又称为I18N标签库,主要用来编写国际化的WEB应用,使用此功能可以对一个特定的语言请求做出合适的处理. 例如:中国内地用户将显示简体中文,台湾地区则显示繁体中文,使用I18N格 ...

  2. jsp中引用的jstl 和fmt标签-详解

    JSTL 核心标签库标签共有13个,功能上分为4类: 1.表达式控制标签:out.set.remove.catch 2.流程控制标签:if.choose.when.otherwise 3.循环标签:f ...

  3. python学习之路基础篇(第五篇)

    前四天课程回顾 1.python简介 2.python基本数据类型 类: int:整型 | str:字符串 | list:列表 |tuple:元组 |dict:字典 | set:集合 对象: li = ...

  4. jstl fmt标签的使用

    所有标签 fmt:requestEncoding fmt:setLocale fmt:timeZone fmt:setTimeZone fmt:bundle fmt:setBundle fmt:mes ...

  5. JSTL中的fmt标签小例子

    <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding= ...

  6. [原创]java WEB学习笔记52:国际化 fmt 标签,国际化的总结

    本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...

  7. 国际化之fmt标签

    1. 什么是国际化和本地化: I. 本地化:一个软件在某个国家或地区使用时,采用该国家或地区的语言,数字,货币,日期等习惯.II. 国际化:软件开发时,让它能支持多个国家和地区的本地化应用.使得应用软 ...

  8. JSP第五篇【JSTL的介绍、core标签库、fn方法库、fmt标签库】

    什么是JSTL JSTL全称为 JSP Standard Tag Library 即JSP标准标签库. JSTL作为最基本的标签库,提供了一系列的JSP标签,实现了基本的功能:集合的遍历.数据的输出. ...

  9. mysql第五篇 : MySQL 之 视图、触发器、存储过程、函数、事物与数据库锁

    第五篇 : MySQL 之 视图.触发器.存储过程.函数.事物与数据库锁 一.视图 视图是一个虚拟表(非真实存在的),其本质是‘根据SQL语句获取动态的数据集,并为其命名‘ ,用户使用时只需使用“名称 ...

随机推荐

  1. Android开发第二阶段(2)

    昨天:总结了第一阶段的开发经验 今天:学习了一下java中对事件处理这块的初步了解比如设置监听器等 明天:我会走进我们的代码去看看相关的一些知识.

  2. 基础系列(1)—— NET框架及C#语言

    一.在.NET之前的编程世界 C#语言是在微软公司的.NET框架上开发程序而设计的,首先作者给大家纠正了一下C#的正确发音:See Sharp (一) 20世纪90年代末的Windows编程 这时大多 ...

  3. 常用IDE插件

    Visual Studio 常用 Refactoring Essentials:代码重构分析 Roslynator:代码重构 CodeMaid:代码格式化 Github Extension for V ...

  4. texbbox,combobox设置属性

    --输入框 $("#xx").textbox('setValue','value');  //设置输入框的值 $('#xx').textbox('textbox').attr('r ...

  5. 3dContactPointAnnotationTool开发日志(三四)

      今天就是让背景图可以变大变小,变透明度,然后将3d的点投影到图片上,输出2d接触点信息:   可以看到输出了正确的接触点信息:   然后还把空物体的包围盒大小设置为边长为0.1的的正方体,点击选中 ...

  6. 【beta】nice!-------约吧NABCD

    小组名称:nice! 组长:李权 成员:于淼  刘芳芳韩媛媛 宫丽君 项目内容:约跑app(约吧) 约吧APP下载地址: 百度云:链接:http://pan.baidu.com/s/1jHNBR3g ...

  7. Python——cmd调用(os.system阻塞处理)(多条命令执行)

    os.system(返回值为0,1,2)方法 0:成功 1:失败 2:错误 os.system默认阻塞当前程序执行,在cmd命令前加入start可不阻塞当前程序执行. 例如: import os os ...

  8. PHP qrcode 生成二维码

    <?php /* 下载地址 : https://sourceforge.net/projects/phpqrcode/ 这里下载的文件名为 phpqrcode-2010100721_1.1.4 ...

  9. Node.js系列——(2)发起get/post请求

    服务器与浏览器的交互主要方式有get/post请求. 下面,我们来看一下node.js发起get/post请求. 1.get 由于get请求的参数在url后面,所以相对比较简单.node.js中的ur ...

  10. Win10 版本情况 201810