찾다
웹 프론트엔드JS 튜토리얼JS_javascript 기술로 구현된 4개의 디지털 천 자리 서식 지정 방법 공유

소위 천 단위 숫자, 즉 한 자리부터 시작하여 세 자리마다 쉼표를 추가하는 방식입니다. 예를 들어 "10,000"입니다. 이 요구 사항에 대응하여 처음에는 다음과 같은 함수를 작성했습니다.

코드 복사 코드는 다음과 같습니다.

//방법 1
함수 toThousands(num) {
var 결과 = [ ], 카운터 = 0;
num = (num || 0).toString().split('');
for (var i = num.length - 1; i >= 0; i--) {
카운터 ;
         result.unshift(num[i]);
If (!(카운터 % 3) && i != 0) { result.unshift(',') }
}
결과 반환.join('');
}

방법 1의 실행 과정은 숫자를 문자열로 변환하고 배열로 나눈 다음 배열의 요소를 끝부터 하나씩 새 배열(결과)의 시작 부분에 삽입하는 것입니다. 요소가 삽입될 때마다 counter는 한 번씩 계산됩니다(더하기 1). counter가 3의 배수이면 쉼표가 삽입되지만 처음에는 쉼표가 필요하지 않습니다(i가 0인 경우). 마지막으로 새 배열의 Join 메소드를 호출하여 결과를 얻습니다.

방법 1은 비교적 명확하고 이해하기 쉬우며 한동안 프로젝트에서 사용되었습니다. 하지만 내 직감으로는 성능이 좋지 않다는 것을 알 수 있습니다.

방법 2 - 방법 1의 문자열 버전

코드 복사 코드는 다음과 같습니다.

//방법 2
함수 toThousands(num) {
var 결과 = '', 카운터 = 0;
num = (num || 0).toString();
for (var i = num.length - 1; i >= 0; i--) {
카운터 ;
결과 = num.charAt(i) 결과;
If (!(카운터 % 3) && i != 0) { 결과 = ',' 결과 }
}
결과 반환;
}

방법 2는 방법 1의 향상된 버전입니다. 문자열을 배열로 나누지 않고 항상 문자열에 대해 작동합니다.

방법 3 - 마지막 세 숫자를 일치시키는 루프

코드 복사 코드는 다음과 같습니다.

//방법 3
함수 toThousands(num) {
var num = (num || 0).toString(), re = /d{3}$/, result = '';
동안 ( re.test(num) ) {
          결과 = RegExp.lastMatch 결과;
If (num !== RegExp.lastMatch) {
              결과 = ',' 결과;
               num = RegExp.leftContext;
         } else {
             숫자 = '';
             휴식;
}
}
If (num) { 결과 = num 결과 }
결과 반환;
}

방법 3은 정규식을 반복하여 마지막 숫자 3개를 일치시킬 때마다 쉼표와 일치하는 내용을 결과 문자열의 시작 부분에 삽입한 다음 일치하는 항목을 찾습니다. target (num) 아직 일치하지 않은 콘텐츠(RegExp.leftContext)에 값을 할당합니다. 또한 참고하세요:

1. 자릿수가 3의 배수인 경우 마지막으로 일치하는 내용은 3자리여야 하지만, 처음 3자리 앞에 쉼표를 추가할 필요는 없습니다. 2. 숫자의 자릿수가 3의 배수가 아닌 경우 끝의 num 변수에 확실히 1 또는 2개의 숫자가 남게 됩니다. 나머지 숫자는 루프의 시작 부분에 삽입되어야 합니다. 결과 문자열.

방법 3은 루프 수를 줄이지만(한 루프에서 세 문자를 처리함) 정규식 사용으로 인해 어느 정도 소비가 늘어납니다.

방법 4 - 방법 3의 문자열 버전


코드 복사 코드는 다음과 같습니다.

//방법 4
함수 toThousands(num) {
var num = (num || 0).toString(), result = '';
while (숫자.길이 > 3) {
          결과 = ',' num.slice(-3) 결과;
​​​​ num = num.slice(0, num.length - 3);
}
If (num) { 결과 = num 결과 }
결과 반환;
}

실제로 마지막 세 문자를 가로채는 기능은 string형의 Slice, substr, substring 방식을 통해 구현할 수 있습니다. 이렇게 하면 정규식 사용을 피할 수 있습니다.

방법 5 - 그룹화 및 병합 방법

코드 복사 코드는 다음과 같습니다.

//방법 5
함수 toThousands(num) {
var num = (num || 0).toString(), temp = num.length % 3;
스위치(임시) {
사례 1:
              숫자 = '00' 숫자;
             휴식;
사례 2:
              숫자 = '0' 숫자;
             휴식;
}
num.match(/d{3}/g).join(',').replace(/^0 /, '');
를 반환합니다. }

먼저 자릿수를 3의 배수로 보완하고 정규식을 사용하여 세 자리 그룹으로 나눈 다음 조인 방법을 통해 쉼표를 추가하고 마지막으로 보완된 0을 제거합니다.

방법 6 - 게으른 남자의 방법

코드 복사 코드는 다음과 같습니다.

//방법 6
함수 toThousands(num) {
Return (num || 0).toString().replace(/(d)(?=(?:d{3}) $)/g, '$1,');
}

이 형식화는 정규 표현식을 대체하면 가능하다고 항상 느꼈지만, 이를 위해서는 단언문 및 기타 작성 방법을 사용해야 합니다. 안타깝게도 이 부분은 익숙하지 않습니다. Google에서 검색한 결과 실제로 이러한 정규식을 찾았습니다. 이는 아마도 코드의 가장 짧은 구현일 것입니다.

테스트 결과

数字 执行5000次消耗的时间(ms)
方法一 方法二 方法三 方法四 方法五 方法六
1 4 1 3 1 14 2
10 14 1 3 0 7 2
100 12 1 2 4 5 3
1000 13 2 3 2 9 5
10000 21 4 3 1 6 3
100000 21 3 2 1 5 6

방법 1과 방법 2를 강력하게 비교하면 문자열 작업의 효율성이 배열 작업의 효율성보다 훨씬 높다는 것을 알 수 있습니다. 방법 6의 테스트 결과는 코드 길이가 성능과 관련이 없음을 보여줍니다. 방법 4가 전체적으로 성능이 가장 좋습니다(그런데 num이 100일 때 성능이 저하되는 이유는 정말 이해가 되지 않습니다).

1. 방법 1과 2를 비교하면 각 작업은 루프 수를 줄이기 위해 1자가 아닌 3자를 사용합니다. 2. 방법 3, 5, 6에 비해 정규식을 사용하지 않아 소모량이 줄어든다.

마지막으로 최종 최적화 솔루션으로 방법 4를 선택했습니다. 독자들에게 더 나은 구현 방법이나 개선을 위한 제안 사항이 있으면 댓글을 남길 수 있습니다.

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
JavaScript 및 웹 : 핵심 기능 및 사용 사례JavaScript 및 웹 : 핵심 기능 및 사용 사례Apr 18, 2025 am 12:19 AM

웹 개발에서 JavaScript의 주요 용도에는 클라이언트 상호 작용, 양식 검증 및 비동기 통신이 포함됩니다. 1) DOM 운영을 통한 동적 컨텐츠 업데이트 및 사용자 상호 작용; 2) 사용자가 사용자 경험을 향상시키기 위해 데이터를 제출하기 전에 클라이언트 확인이 수행됩니다. 3) 서버와의 진실한 통신은 Ajax 기술을 통해 달성됩니다.

JavaScript 엔진 이해 : 구현 세부 사항JavaScript 엔진 이해 : 구현 세부 사항Apr 17, 2025 am 12:05 AM

보다 효율적인 코드를 작성하고 성능 병목 현상 및 최적화 전략을 이해하는 데 도움이되기 때문에 JavaScript 엔진이 내부적으로 작동하는 방식을 이해하는 것은 개발자에게 중요합니다. 1) 엔진의 워크 플로에는 구문 분석, 컴파일 및 실행; 2) 실행 프로세스 중에 엔진은 인라인 캐시 및 숨겨진 클래스와 같은 동적 최적화를 수행합니다. 3) 모범 사례에는 글로벌 변수를 피하고 루프 최적화, Const 및 Lets 사용 및 과도한 폐쇄 사용을 피하는 것이 포함됩니다.

Python vs. JavaScript : 학습 곡선 및 사용 편의성Python vs. JavaScript : 학습 곡선 및 사용 편의성Apr 16, 2025 am 12:12 AM

Python은 부드러운 학습 곡선과 간결한 구문으로 초보자에게 더 적합합니다. JavaScript는 가파른 학습 곡선과 유연한 구문으로 프론트 엔드 개발에 적합합니다. 1. Python Syntax는 직관적이며 데이터 과학 및 백엔드 개발에 적합합니다. 2. JavaScript는 유연하며 프론트 엔드 및 서버 측 프로그래밍에서 널리 사용됩니다.

Python vs. JavaScript : 커뮤니티, 라이브러리 및 리소스Python vs. JavaScript : 커뮤니티, 라이브러리 및 리소스Apr 15, 2025 am 12:16 AM

Python과 JavaScript는 커뮤니티, 라이브러리 및 리소스 측면에서 고유 한 장점과 단점이 있습니다. 1) Python 커뮤니티는 친절하고 초보자에게 적합하지만 프론트 엔드 개발 리소스는 JavaScript만큼 풍부하지 않습니다. 2) Python은 데이터 과학 및 기계 학습 라이브러리에서 강력하며 JavaScript는 프론트 엔드 개발 라이브러리 및 프레임 워크에서 더 좋습니다. 3) 둘 다 풍부한 학습 리소스를 가지고 있지만 Python은 공식 문서로 시작하는 데 적합하지만 JavaScript는 MDNWebDocs에서 더 좋습니다. 선택은 프로젝트 요구와 개인적인 이익을 기반으로해야합니다.

C/C에서 JavaScript까지 : 모든 것이 어떻게 작동하는지C/C에서 JavaScript까지 : 모든 것이 어떻게 작동하는지Apr 14, 2025 am 12:05 AM

C/C에서 JavaScript로 전환하려면 동적 타이핑, 쓰레기 수집 및 비동기 프로그래밍으로 적응해야합니다. 1) C/C는 수동 메모리 관리가 필요한 정적으로 입력 한 언어이며 JavaScript는 동적으로 입력하고 쓰레기 수집이 자동으로 처리됩니다. 2) C/C를 기계 코드로 컴파일 해야하는 반면 JavaScript는 해석 된 언어입니다. 3) JavaScript는 폐쇄, 프로토 타입 체인 및 약속과 같은 개념을 소개하여 유연성과 비동기 프로그래밍 기능을 향상시킵니다.

JavaScript 엔진 : 구현 비교JavaScript 엔진 : 구현 비교Apr 13, 2025 am 12:05 AM

각각의 엔진의 구현 원리 및 최적화 전략이 다르기 때문에 JavaScript 엔진은 JavaScript 코드를 구문 분석하고 실행할 때 다른 영향을 미칩니다. 1. 어휘 분석 : 소스 코드를 어휘 단위로 변환합니다. 2. 문법 분석 : 추상 구문 트리를 생성합니다. 3. 최적화 및 컴파일 : JIT 컴파일러를 통해 기계 코드를 생성합니다. 4. 실행 : 기계 코드를 실행하십시오. V8 엔진은 즉각적인 컴파일 및 숨겨진 클래스를 통해 최적화하여 Spidermonkey는 유형 추론 시스템을 사용하여 동일한 코드에서 성능이 다른 성능을 제공합니다.

브라우저 너머 : 실제 세계의 JavaScript브라우저 너머 : 실제 세계의 JavaScriptApr 12, 2025 am 12:06 AM

실제 세계에서 JavaScript의 응용 프로그램에는 서버 측 프로그래밍, 모바일 애플리케이션 개발 및 사물 인터넷 제어가 포함됩니다. 1. 서버 측 프로그래밍은 Node.js를 통해 실현되며 동시 요청 처리에 적합합니다. 2. 모바일 애플리케이션 개발은 재교육을 통해 수행되며 크로스 플랫폼 배포를 지원합니다. 3. Johnny-Five 라이브러리를 통한 IoT 장치 제어에 사용되며 하드웨어 상호 작용에 적합합니다.

Next.js (백엔드 통합)로 멀티 테넌트 SAAS 애플리케이션 구축Next.js (백엔드 통합)로 멀티 테넌트 SAAS 애플리케이션 구축Apr 11, 2025 am 08:23 AM

일상적인 기술 도구를 사용하여 기능적 다중 테넌트 SaaS 응용 프로그램 (Edtech 앱)을 구축했으며 동일한 작업을 수행 할 수 있습니다. 먼저, 다중 테넌트 SaaS 응용 프로그램은 무엇입니까? 멀티 테넌트 SAAS 응용 프로그램은 노래에서 여러 고객에게 서비스를 제공 할 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경