read-vietnamese-number
v2.3.0
Published
Convert numbers to text in Vietnamese
Maintainers
Readme
read-vietnamese-number-js
Thư viện đọc số thành chữ trong Tiếng Việt, với các tính năng:
- Hỗ trợ số âm, số thập phân, số lớn tùy ý
- Có nhiều tùy chọn: đơn vị tính, dấu phân tách,...
- Hoạt động tốt trong trình duyệt và Node.js
Hỗ trợ TypeScript, tương thích với JavaScript từ ES6 trở lên. Hoạt động với các module system như ESM và CommonJS.
Live demo tại https://tonghoangvu.github.io/read-vietnamese-number-js/.
Bạn cũng có thể test nhanh thư viện với npx command mà không cần cài đặt.
npx read-vietnamese-number 3.14
# ba chấm mười bốn đơn vịInstallation
Cài đặt thư viện với NPM, Yarn hoặc các package manager khác.
# NPM
npm install read-vietnamese-number
# Yarn
yarn add read-vietnamese-numberHoặc sử dụng trực tiếp trong browser thông qua CDN (hoặc tự host). Chú ý nên kèm theo version cố định trong CDN URL, ví dụ như https://cdn.jsdelivr.net/npm/[email protected]/+esm (đây không phải version mới nhất).
<script type="module">
import {} from 'https://cdn.jsdelivr.net/npm/read-vietnamese-number/+esm'
// ...
</script>Usage
Cách sử dụng gồm 3 bước:
- Tạo cấu hình đọc số và điều chỉnh phù hợp
- Đọc chuỗi số với cấu hình đã tạo
- Xử lý lỗi phát sinh
Code example
import { InvalidNumberError, ReadingConfig, doReadNumber } from 'read-vietnamese-number' // or CDN URL
// Config reading options
const config = new ReadingConfig()
config.unit = ['đồng']
try {
// Start reading
const number = '-12345.6789'
const result = doReadNumber(number, config)
console.log(result)
} catch (err) {
// Handle errors
if (err instanceof InvalidNumberError) {
console.error('Số không hợp lệ')
} else {
console.error(err)
}
}Error handling
Thư viện ném ra 2 loại ReadVietnameseNumberError sau nếu có lỗi trong quá trình đọc số:
TypeErrorkhi input không hợp lệInvalidNumberErrorkhi số chứa ký tự không hợp lệ
Hàm doReadNumber() chấp nhận input là string và bigint, ném TypeError với các trường hợp khác.
Hành vi này liên quan đến các vấn đề định dạng số của JavaScript (tràn số, mất độ chính xác,...).
Đây là error hoàn toàn tránh được ở runtime nếu type của input là string hoặc bigint.
Từ version 2.2.0, thư viện hỗ trợ đọc số với độ lớn không giới hạn. Nên nâng cấp lên version này để tránh các vấn đề khi đọc số lớn (issue #38).
Với các version cũ hơn, thư viện sẽ ném NotEnoughUnitError nếu cấu hình đọc số không có đủ số lượng đơn vị phù hợp.
Nên giới hạn độ lớn số nhập vào cho phù hợp với các đơn vị hiện có (mặc định hỗ trợ đến tỉ tỉ).
Ngoài ra có thể xử lý bằng cách thêm các đơn vị lớn hơn vào cấu hình (không khuyến khích).
