原生js实现数字三位逗号,分隔。js实现支持逗号分割的货币格式表示法总汇

时间: 2017-12-05阅读: 5506标签: js知识

原生js实现数字三位逗号,分隔。js实现支持货币格式表示法


方法一:

function setMoney(num){//取整,三行逗号隔开
	return parseFloat(num).toLocaleString();
	
}
var m=setMoney(123456.7889);
console.log(m);//输出123,456.789

说明:toLocaleString在将数字转换为字符串的同时,会使用三位分节法进行显示。如果是浮点数,只只保留了小数点后三位数,并进行了四舍五入。

注意:在IE下,浮动数会默认取消,输出结果为123,456


方法二:

function setnum(num){//取整,三行逗号隔开
	/*//获取小数位
    var right=String(num).split('.')[1];
    right=(right==undefined)?'':right;
    */
   num=Math.floor(num);//向下取整,
   num=num.toString(); 
   var len=num.length,
   		r=len%3;
   if(len<=3){
   	return num;
   }
   num=r>0?num.slice(0,r)+","+num.slice(r,len).match(/\d{3}/g).join(","):num.slice(r,len).match(/\d{3}/g).join(","); 
   return num; 
};
var m=setnum(123456.789);
console.log(m);//输出123,456

说明:slice 方法用于截取字符串中的一部分并返回该部分字符串。match方式代表正则表达式的匹配,最后通过join将元素放入一个字符串,用逗号隔开。


方法三

function setnum(num){//保留2位小数,如果没小数位自动补全.00
    if(num && num!=null){  
        num = String(num);  
        var left=num.split('.')[0],right=num.split('.')[1];  
        right = right ? (right.length>=2 ? '.'+right.substr(0,2) : '.'+right+'0') : '.00';  
        var temp = left.split('').reverse().join('').match(/(\d{1,3})/g);  
        return (Number(num)<0?"-":"") + temp.join(',').split('').reverse().join('')+right;  
    }else if(num===0){   //注意===在这里的使用,如果传入的num为0,if中会将其判定为boolean类型,故而要另外做===判断  
        return '0.00';  
    }else{  
        return "";  
    }  
};  
var m=setnum(123456.789);
console.log(m);//输出123,456.78
m=setnum(123456);
console.log(m);//输出123,456.00

如果要将123,456.78转换为123456.78呢?如下:

function undonum(num){  
    if(num && num!=null){  
        num = String(num);  
        var group = num.split('.');  
        var left = group[0].split(',').join('');  
        return Number(left+"."+group[1]);  
    }else{  
        return "";  
    }  
}; 
var m=undonum('123,456.789');
console.log(m);//输出123456.789


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/221

关闭

Performance_js中计算网站性能监控利器

Performance提供的方法可以灵活使用,获取到页面加载等标记的耗时情况。Performance.timing属性对象提供了浏览器从打开网页到加载完成之间各个节点的耗时数据,包括重定向开始、DNS查询、浏览器响应数据、DOM解析等相关节点

JavaScript中的行为委托

行为委托简单来说就是一种设计模式,不同于传统的构造函数的类式设计。这里每个例子会通过构造函数,class和行为委托来不同实现,不过不会评论class,是否使用class取决于你的观点。

JavaScript中公有、私有、静态、受保护的属性和方法

在开发中,我们需要限制某些属性和方法的暴露程度,使得它们不能通过对象实例本身被访问、修改或调用。要了解js面向对象,就必需先了解js中什么是公有、私有、静态、受保护。

js原型链,Javascript重温OOP之原型与原型链

js的原型链,得出了一个看似很简单的结论。对于一个对象上属性的查找是递归的。查找属性会从自身属性(OwnProperty)找起,如果不存在,就查看prototype中的存在不存在。

JavaScript中的特殊运算,一些有趣的js等式

JavaScript中的特殊运算,字符,true,false参与运算结果会怎么样?打开控制台。这会允许你再你的浏览器里输入下面所有的代码,所以你可以实时的看到发生什么了。

base91 for javascript

原理和 base64 是一样的,ASCII 共有94个可打印字符,base64 使用了其中 64 个,base91 使用了 91 个。

7个常见的 JavaScript 测验及解答

我相信学习新事物并评估我们所知的东西对自己的进步非常有用,可以避免了我们觉得自己的知识过时的情况。在本文中,我将介绍一些常见的 JavaScript 知识。请享用!

window.location.href的用法(动态输出跳转)

javascript中的location.href有很多种用法,window.location.href 语句可以实现一个框架的页面在执行服务器端代码后刷新另一个框架的页面

理解js中prototype和__proto__和的区别和作用?

在js中有句话叫一切皆对象,而几乎所有对象都具有__proto__属性,可称为隐式原型,除了Object.prototype这个对象的__proto__值为null。Js的prototype属性的解释是:返回对象类型原型的引用。每个对象同样也具有prototype属性,除了Function.prototype.bind方法构成的对象外。

Js中的命名空间(namespace)

全局变量应该由有系统范围相关性的对象们保留,并且它们的命名应该避免含糊并尽量减少命名冲突的风险。在实践中,这意味着你应该避免创建全局对象,除非它们是绝对必须的。 所以你对此是怎么做的?传统方法告诉我们,最好的消除全局策略是创建少数作为潜在模块和子系统的实际命名空间的全局对象。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!