Javascript 正則表達式實現(xiàn)為數(shù)字添加千位分隔符
更新時間:2015年03月10日 09:39:26 投稿:hebedich
在項目中做貨幣轉換的時候經常需要可以實現(xiàn)自動格式化輸入的數(shù)字,自動千位分隔符,在網上也看到一些其他網友的實現(xiàn)的代碼,感覺都不是太滿意,于是自己研究了下,分享給大家。
最近在網上有看到使用js來實現(xiàn)數(shù)字的千位分隔符的面試(筆試)題,所以就自己寫了一個利用“正則+replace”來實現(xiàn)的方法:
復制代碼 代碼如下:
var thousandBitSeparator = function(numStr){
var b = /([-+]?\d{3})(?=\d)/g;
return numStr.replace(b, function($0, $1){
return $1 + ',';
});
}
支持正負號匹配,小數(shù)點區(qū)分,如有錯誤,希望大大們指出:-D
附上一個其他網友的實現(xiàn)方法
復制代碼 代碼如下:
<script language="JavaScript" type="text/javascript">
function formatNumber(num){
if(!/^(\+|-)?(\d+)(\.\d+)?$/.test(num)){
return num;
}
var a = RegExp.$1,b = RegExp.$2,c = RegExp.$3;
var re = new RegExp().compile("(\\d)(\\d{3})(,|$)");
while(re.test(b)){
b = b.replace(re,"$1,$2$3");
}
return a +""+ b +""+ c;
}
var num=1234567/3;
alert("num="+num+",四舍五入:"+Math.round(num)+",兩位有效數(shù)字:"+num.toFixed(2)+",添加千位分隔符:"+formatNumber(num));
</script>
以上就是本文的全部內容了,希望大家能夠喜歡。
您可能感興趣的文章:
- JS正則表達式驗證數(shù)字代碼
- js限制文本框只能輸入數(shù)字(正則表達式)
- js正則表達式匹配數(shù)字字母下劃線等
- js中判斷數(shù)字\字母\中文的正則表達式 (實例)
- JavaScript基于正則表達式的數(shù)字判斷函數(shù)
- javascript 數(shù)字的正則表達式集合
- JS正則表達式匹配檢測各種數(shù)值類型(數(shù)字驗證)
- 怎么限制input的text里輸入的值只能是數(shù)字(正則、js)
- js正則表達式實現(xiàn)數(shù)字每隔四位用空格分隔代碼
- js中使用正則表達式查找字母和數(shù)字的方法
- JS基于正則實現(xiàn)數(shù)字千分位用逗號分隔的方法
相關文章
createObjectURL方法實現(xiàn)本地圖片預覽
這篇文章主要為大家詳細介紹了createObjectURL方法實現(xiàn)本地圖片預覽,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-09-09