freemarker保留小数

freemarker保留两位小数

方法一

    #{number ;m1M2}    m 最少几位小数,M最多几位小数

方法二

  ${x?string("0.##")}    


在开发中很容易忽视一点,输入一个值(可能是小数),输出时如果不做处理,就很容易出现 
隐形的BUG。比如,如果从数据库取出一个0.22的数值,一般的输出${x?if_exists?html}, 
这时是显示0,而不是0.22。 
应该写成${x?if_exists?string.number} 或者 ${x?if_exists.toString()?html} 



1, 小于1的数字在freemarker中相减错误

 

2,1000,2000这类的数字在freemarker中的格式错误,会被解释成1,000

 

解决方法设置number在freemarker的显示格式

 

Xml代码   收藏代码
  1. <#setting number_format="0.00">  
  2.     <#assign x="${goodsgroupt.memberprice}"/>  
  3.     <#assign y="${goodsgroupt.groupprice}"/>  
  4.     ${(x?number-y?number)}  

 

重点就是这个number_format了

网上说让number_format="0",这样只能解决第二种情况。


四、局部设置
特点:
如果在某个页面,或者某几个页面(其它页面可import进来),用到的数字格式化是相同的,可考虑统一配置数字的格式化形式
用法:
只需在用到需要格式化的数字之前 设置就可以了,格式如下: <#setting number_format=",##0.##">  其中",##0.##"的内容是采用类似于java中数字格式的语法形式,也就是以上的第三点。
注意:
如果用在一个页面,则整个页面默认就是那种格式,除非用string函数覆盖了默认的格式,同样的,如果放在一个公共的页面,其它页面只要include它,也会是同样的格式。
五、全局设置
特点:
在所有的页面都默认提供数字的格式化形式
用法
(针对spring):在freemarker的配置文件中设置其默认的数字格式化形式,如下:

 代码如下 复制代码
< property name = "freemarkerSettings" >
          < props>
               .....
              < prop key = "number_format"> 0.##
                ......
         


你可能感兴趣的:(freemarker保留小数)