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ị
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-number
Hoặ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/read-vietnamese-number@2.0.0/+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>
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
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)
}
}
Thư viện ném ra 2 loại ReadVietnameseNumberError
sau nếu có lỗi trong quá trình đọc số:
TypeError
khi input không hợp lệInvalidNumberError
khi 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).