js格式化金额可选是否带千分位以及保留精度


Posted in Javascript onJanuary 28, 2014

js格式化金额,可选是否带千分位,可选保留精度,也是网上搜到的,但是使用没问题

/* 
将数值四舍五入后格式化. 
@param num 数值(Number或者String) 
@param cent 要保留的小数位(Number) 
@param isThousand 是否需要千分位 0:不需要,1:需要(数值类型); 
@return 格式的字符串,如'1,234,567.45' 
@type String 
*/ 
function formatNumber(num,cent,isThousand){ 
num = num.toString().replace(/\$|\,/g,''); 
if(isNaN(num))//检查传入数值为数值类型. 
num = "0"; 
if(isNaN(cent))//确保传入小数位为数值型数值. 
cent = 0; 
cent = parseInt(cent); 
cent = Math.abs(cent);//求出小数位数,确保为正整数. 
if(isNaN(isThousand))//确保传入是否需要千分位为数值类型. 
isThousand = 0; 
isThousand = parseInt(isThousand); 
if(isThousand < 0) 
isThousand = 0; 
if(isThousand >=1) //确保传入的数值只为0或1 
isThousand = 1; 
sign = (num == (num = Math.abs(num)));//获取符号(正/负数) 
//Math.floor:返回小于等于其数值参数的最大整数 
num = Math.floor(num*Math.pow(10,cent)+0.50000000001);//把指定的小数位先转换成整数.多余的小数位四舍五入. 
cents = num%Math.pow(10,cent); //求出小数位数值. 
num = Math.floor(num/Math.pow(10,cent)).toString();//求出整数位数值. 
cents = cents.toString();//把小数位转换成字符串,以便求小数位长度. 
while(cents.length<cent){//补足小数位到指定的位数. 
cents = "0" + cents; 
} 
if(isThousand == 0) //不需要千分位符. 
return (((sign)?'':'-') + num + '.' + cents); 
//对整数部分进行千分位格式化. 
for (var i = 0; i < Math.floor((num.length-(1+i))/3); i++) 
num = num.substring(0,num.length-(4*i+3))+','+ 
num.substring(num.length-(4*i+3)); 
return (((sign)?'':'-') + num + '.' + cents); 
}
Javascript 相关文章推荐
用JavaScript事件串连执行多个处理过程的方法
Mar 09 Javascript
深入理解JavaScript高级之词法作用域和作用域链
Dec 10 Javascript
js的回调函数详解
Jan 05 Javascript
体验jQuery和AngularJS的不同点及AngularJS的迷人之处
Feb 02 Javascript
JavaScript 正则表达式中global模式的特性
Feb 25 Javascript
jQuery ajax应用总结
Jun 02 Javascript
Express + Node.js实现登录拦截器的实例代码
Jul 01 Javascript
vue实现全选和反选功能
Aug 31 Javascript
Element-ui tree组件自定义节点使用方法代码详解
Sep 17 Javascript
jquery实现的分页显示功能示例
Aug 23 jQuery
JavaScript简易计算器制作
Jan 17 Javascript
在项目vue中使用echarts的操作步骤
Sep 07 Javascript
js关于精确计算和数值格式化以及直接引js文件
Jan 28 #Javascript
键盘上一张下一张兼容IE/google/firefox等浏览器
Jan 28 #Javascript
调用innerHTML之后onclick失效问题的解决方法
Jan 28 #Javascript
JS判断两个时间大小的示例代码
Jan 28 #Javascript
js jquery ajax的几种用法总结(及优缺点介绍)
Jan 28 #Javascript
js中哈希表的几种用法总结
Jan 28 #Javascript
js日期对象兼容性的处理方法
Jan 28 #Javascript
You might like
php iconv() : Detected an illegal character in input string
2010/12/05 PHP
一些php技巧与注意事项分析
2011/02/03 PHP
php笔记之:数据类型与常量的使用分析
2013/05/14 PHP
PHP轻量级数据库操作类Medoo增加、删除、修改、查询例子
2014/07/04 PHP
如何使用Gitblog和Markdown建自己的博客
2015/07/31 PHP
PHP实现在windows下配置sendmail并通过mail()函数发送邮件的方法
2017/06/20 PHP
用javascript getComputedStyle获取和设置style的原理
2008/10/10 Javascript
基于jquery的关于动态创建DOM元素的问题
2010/12/24 Javascript
常用的几段javascript代码分享
2014/03/25 Javascript
原生JavaScript编写俄罗斯方块
2015/03/30 Javascript
jquery实现动态改变div宽度和高度
2015/05/08 Javascript
jQuery EasyUI 布局之动态添加tabs标签页
2015/11/18 Javascript
浅谈js中function的参数默认值
2017/02/20 Javascript
分析javascript中9 个常见错误阻碍你进步
2017/09/18 Javascript
Angular开发实践之服务端渲染
2018/03/29 Javascript
js正则相关知识点专题
2018/05/10 Javascript
javascript显示动态时间的方法汇总
2018/07/06 Javascript
nodejs中函数的调用实例详解
2018/10/31 NodeJs
使用rollup打包JS的方法步骤
2018/12/05 Javascript
Node.js之删除文件夹(含递归删除)代码实例
2019/09/09 Javascript
浅析JS中NEW的实现原理及重写
2020/02/20 Javascript
jQuery 图片查看器插件 Viewer.js用法简单示例
2020/04/04 jQuery
微信小程序仿抖音视频之整屏上下切换功能的实现代码
2020/05/24 Javascript
Python编码时应该注意的几个情况
2013/03/04 Python
Python CSV模块使用实例
2015/04/09 Python
Python正则简单实例分析
2017/03/21 Python
Python实现MySQL操作的方法小结【安装,连接,增删改查等】
2017/07/12 Python
Python温度转换实例分析
2018/01/17 Python
Python简单基础小程序的实例代码
2019/04/28 Python
Python 中pandas索引切片读取数据缺失数据处理问题
2019/10/09 Python
Python实现上下文管理器的方法
2020/08/07 Python
端午节演讲稿
2014/05/23 职场文书
企业晚会策划方案
2014/05/29 职场文书
部门2014年度工作总结
2014/11/12 职场文书
Python 快速验证代理IP是否有效的方法实现
2021/07/15 Python
java版 联机五子棋游戏
2022/05/04 Java/Android