> 웹 프론트엔드 > JS 튜토리얼 > Javascript는 숫자 값을 금액 형식으로 변환합니다(천분의 일을 구분하고 자동으로 소수점 추가).

Javascript는 숫자 값을 금액 형식으로 변환합니다(천분의 일을 구분하고 자동으로 소수점 추가).

高洛峰
풀어 주다: 2017-01-09 14:37:53
원래의
1437명이 탐색했습니다.

프로젝트에서 '450000'과 유사한 숫자를 회계에 사용되는 형식인 '450,000.00'으로 변환해야 하는 경우에 천 번째 자리와 소수점을 구분하여 두 자리가 부족할 경우 여러 유형이 기록되어 있습니다. 구현 방법

ps: 마지막에 소수점을 고려하지 않는 경우 가장 빠른 방법은 다음과 같습니다.

"12345678".replace (/[0-9]+?(?=(?:( [0-9]{3}))+$)/g,function(a){return a+','}); //출력 12 345 678

1. 루프를 사용하여 구현

function formatNum(str){
 var newStr = "";
 var count = 0;
 
 if(str.indexOf(".")==-1){
  for(var i=str.length-1;i>=0;i--){
   if(count % 3 == 0 && count != 0){
    newStr = str.charAt(i) + "," + newStr;
   }else{
    newStr = str.charAt(i) + newStr;
   }
   count++;
  }
  str = newStr + ".00"; //自动补小数点后两位
  console.log(str)
 }
 else
 {
  for(var i = str.indexOf(".")-1;i>=0;i--){
   if(count % 3 == 0 && count != 0){
    newStr = str.charAt(i) + "," + newStr; //碰到3的倍数则加上“,”号
   }else{
    newStr = str.charAt(i) + newStr; //逐个字符相接起来
   }
   count++;
  }
  str = newStr + (str + "00").substr((str + "00").indexOf("."),3);
  console.log(str)
 }
}
 
formatNum('13213.24'); //输出13,213.34
formatNum('132134.2'); //输出132,134.20
formatNum('132134'); //输出132,134.00
formatNum('132134.236'); //输出132,134.236
로그인 후 복사

2. 더 똑똑한 정규식 있으면 알려주세요~)

function regexNum(str){
 var regex = /(\d)(?=(\d\d\d)+(?!\d))/g;
 
 if(str.indexOf(".") == -1){
 
  str= str.replace(regex,',') + '.00';
  console.log(str)
 
 }else{
  var newStr = str.split('.');
  var str_2 = newStr[0].replace(regex,',');
 
  if(newStr[1].length <= 1){
   //小数点后只有一位时
   str_2 = str_2 + &#39;.&#39; + newStr[1] +&#39;0&#39;;
   console.log(str_2)
 
  }else if(newStr[1].length > 1){
   //小数点后两位以上时
   var decimals = newStr[1].substr(0,2);
   var srt_3 = str_2 + &#39;.&#39; + decimals;
   console.log(srt_3)
  }
 }
};
regexNum(&#39;23424224&#39;); //输出2,42,224.00
regexNum(&#39;23424224.2&#39;); //输出2,42,224.20
regexNum(&#39;23424224.22&#39;); //输出2,42,224.22
regexNum(&#39;23424224.233&#39;); //输出2,42,224.23
로그인 후 복사

위 내용은 전체 내용입니다. 이 기사에서 JavaScript 구문에 대해 더 자세히 알아보려면 모든 사람이 PHP 중국어 웹사이트를 지원하기를 바랍니다.

숫자를 금액 형식(천분의 일 구분 및 자동으로 소수점 추가)으로 변환하는 Javascript에 대한 자세한 내용은 PHP 중국어 웹사이트에서 관련 기사를 참고하세요!


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿