-
Notifications
You must be signed in to change notification settings - Fork 1
Intl(Internationalization) API
dannysir edited this page Nov 22, 2024
·
1 revision
Intl
은 JavaScript의 국제화 API로, 다양한 언어와 지역에 맞는 날짜, 숫자, 통화 등의 서식을 지원합니다. Intl
객체는 여러 생성자를 제공하여 각각의 용도에 맞는 포맷팅을 할 수 있게 해줍니다.
Intl.NumberFormat
은 숫자를 해당 언어의 표현 방식에 맞게 변환해주는 생성자입니다.
const number = 123456.789;
// 기본 숫자 포맷
console.log(new Intl.NumberFormat('ko-KR').format(number));
// 결과: "123,456.789"
// 통화 표시
console.log(new Intl.NumberFormat('ko-KR', {
style: 'currency',
currency: 'KRW'
}).format(number));
// 결과: "₩123,457"
// 단위 표시
console.log(new Intl.NumberFormat('ko-KR', {
style: 'unit',
unit: 'kilometer-per-hour'
}).format(number));
// 결과: "123,456.789km/h"
const options = {
style: 'decimal' | 'currency' | 'percent' | 'unit',
currency: 'USD' | 'EUR' | 'KRW' | ...,
notation: 'standard' | 'scientific' | 'engineering' | 'compact',
minimumFractionDigits: 0,
maximumFractionDigits: 2
};
// 백만, 억, 조 단위로 표시
const largeNumber = 1234567890;
console.log(new Intl.NumberFormat('ko-KR', {
notation: 'compact',
maximumFractionDigits: 1
}).format(largeNumber));
// 결과: "12.3억"
Intl.DateTimeFormat
은 날짜와 시간을 지역화된 형식으로 표현합니다.
const date = new Date();
// 기본 날짜 표시
console.log(new Intl.DateTimeFormat('ko-KR').format(date));
// 결과: "2024. 3. 21."
// 상세 옵션 지정
console.log(new Intl.DateTimeFormat('ko-KR', {
year: 'numeric',
month: 'long',
day: 'numeric',
weekday: 'long',
hour: 'numeric',
minute: 'numeric',
second: 'numeric',
timeZone: 'Asia/Seoul'
}).format(date));
// 결과: "2024년 3월 21일 목요일 오후 2시 30분 45초"
Intl.Collator
는 문자열 비교와 정렬을 지역화된 방식으로 수행합니다.
const texts = ['제시카', '안나', '바나나', '사과'];
const collator = new Intl.Collator('ko-KR');
// 한글 정렬
console.log(texts.sort(collator.compare));
// 결과: ['안나', '바나나', '사과', '제시카']
// 상품 가격 표시
const price = 1250000;
const formatter = new Intl.NumberFormat('ko-KR', {
style: 'currency',
currency: 'KRW'
});
console.log(formatter.format(price)); // "₩1,250,000"
// 할인율 표시
const discount = 0.15;
const percentFormatter = new Intl.NumberFormat('ko-KR', {
style: 'percent',
minimumFractionDigits: 0
});
console.log(percentFormatter.format(discount)); // "15%"
// 조회수 표시
const views = 1234567;
const compactFormatter = new Intl.NumberFormat('ko-KR', {
notation: 'compact',
maximumFractionDigits: 1
});
console.log(compactFormatter.format(views)); // "123.5만"
// 게시 시간 표시
const postDate = new Date('2024-03-20T15:30:00');
const dateFormatter = new Intl.DateTimeFormat('ko-KR', {
year: 'numeric',
month: 'long',
day: 'numeric',
hour: 'numeric',
minute: 'numeric'
});
console.log(dateFormatter.format(postDate));
// "2024년 3월 20일 오후 3시 30분"
Intl
API는 현재 모든 주요 브라우저에서 지원됩니다:
- Chrome: 24+
- Firefox: 29+
- Safari: 10+
- Edge: 12+
Intl
API는 웹 애플리케이션의 국제화를 매우 쉽게 만들어줍니다. 복잡한 포맷팅 로직을 직접 구현할 필요 없이, 브라우저의 내장 기능을 활용하여 안정적이고 효율적인 국제화를 구현할 수 있습니다.
이 API를 활용하면 다국어 지원이 필요한 웹사이트나 숫자, 날짜 등의 지역화된 표시가 필요한 애플리케이션을 더욱 쉽게 개발할 수 있습니다.
- [FE] 프론트엔드 기술스택
- [FE] 라이브러리 없이 차트 구현 이유
- [FE] Canvas API 사용방법
- [FE] 네비게이션 바 애니메이션 구현
- [FE] Socket.io 사용방법
- [FE] Tanstack Router에 대하여...
- [FE] Intl(Internationalization) API
- [FE] React Suspense 적용
- [FE] 한글 입력 방식의 유연성을 높인 검색 시스템 구현하기
- [BE] 백엔드 기술 스택
- [BE] SSE vs Socket.io
- [BE] Redis를 도입하게 된 계기
- [BE] ACG Rule을 활용한 Secure CI CD 파이프라인 구현
- [BE] Nginx 로드밸런싱을 통해 한국 투자 API 소켓 제한 극복
- [BE] 주가 지수 기능 개발 과정
- [BE] 매수 및 매도 기능 개발 과정
- [BE] 실시간 자산 조회 기능 개발 과정
- [BE] 단위 테스트
- [BE] redis를 이용한 한국투자 Open API 세션 관리
- [BE] 데이터베이스 인덱싱
- [FE] React에서의 DOM 요소 접근 (useRef vs getElementById)
- [FE] Outlet을 활용한 공통 레이아웃 관리
- [FE] react hooks가 특정 조건에서 실행되면 안되는 이유 & useQuery에 query function 매개변수가 undefined일 수도 있을 때 어떻게 해결할까
- [FE] cross‐domain 로컬 환경에서 cookie로 인증 처리하기 with vite proxy
- [FE] 크롬&사파리 Composition 차이
- [FE] useEffect 의존성 배열
- [BE] Naver Cloud Platform HTTPS 무응답 현상
- [BE] 한국투자 Open API에서 access token을 발급받지 못하는 문제
- [BE] 한국투자 Open API와 웹소켓 연결이 되지 않던 문제
- [BE] 한국투자 Open API 웹소켓 연결이 중단되는 문제
- [BE] 같은 주식 주문이 동시에 여러 번 체결되는 문제
- [BE] 한국투자 Open API Websocket 세션을 두 개에서 한 개로 변경하기
- [BE] Nginx 로드 밸런싱 중 Socket bad Request 발생하는 현상
- [BE] 매수/매도 체결 로직에 의해 redis pub/sub이 정상적으로 동작하지 않는 문제