前言:这个功能在前端页面中使用的还是比较多的,正好我们的项目中也有使用此功能,不过YY同学写的代码不像个方法的样子,一个入口中间又插了几道子,所 以,我写了下面这个方法,经过测试,适用性还是蛮好的,留在这里以备后用!
<!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <title>Format Currency</title> <style> input{width:360px;} </style> <script> /* 获取第一个输入框中数据,格式化后放入第二个输入框进行展示 */ function showNewNum() { //获取输入的数据 var value = document.getElementById('num').value; //将格式化的数据放入到新的输入框中显示 document.getElementById('newNum').value = formatCurrency(value); } /* 格式化数据,小数部分不做处理,对整数部分进行千分位格式化的处理,如果有符号,正常保留 */ function formatCurrency(num) { if(num) { //将num中的$,去掉,将num变成一个纯粹的数据格式字符串 num = num.toString().replace(/\$|\,/g,''); //如果num不是数字,则将num置0,并返回 if(''==num || isNaN(num)){return 'Not a Number ! ';} //如果num是负数,则获取她的符号 var sign = num.indexOf("-")> 0 ? '-' : ''; //如果存在小数点,则获取数字的小数部分 var cents = num.indexOf(".")> 0 ? num.substr(num.indexOf(".")) : ''; cents = cents.length>1 ? cents : '' ;//注意:这里如果是使用change方法不断的调用,小数是输入不了的 //获取数字的整数数部分 num = num.indexOf(".")>0 ? num.substring(0,(num.indexOf("."))) : num ; //如果没有小数点,整数部分不能以0开头 if('' == cents){ if(num.length>1 && '0' == num.substr(0,1)){return 'Not a Number ! ';}} //如果有小数点,且整数的部分的长度大于1,则整数部分不能以0开头 else{if(num.length>1 && '0' == num.substr(0,1)){return 'Not a Number ! ';}} //针对整数部分进行格式化处理,这是此方法的核心,也是稍难理解的一个地方,逆向的来思考或者采用简单的事例来实现就容易多了 /* 也可以这样想象,现在有一串数字字符串在你面前,如果让你给他家千分位的逗号的话,你是怎么来思考和操作的? 字符串长度为0/1/2/3时都不用添加 字符串长度大于3的时候,从右往左数,有三位字符就加一个逗号,然后继续往前数,直到不到往前数少于三位字符为止 */ 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); } } </script> </head> <body bgcolor="AliceBlue" align="center"> <input id="num" class=""/><br/> <input id="newNum" class=""/><br/> <input type="button" value="Please click ME" onclick="showNewNum();"/> </body> </html>