ฉันมีข้อกำหนดเดียวกันโดยทั่วไปและพบว่าไม่มีกลไกในตัวสำหรับฟังก์ชันนี้
นอกเหนือจากการตัดค่าศูนย์ต่อท้ายแล้วฉันยังต้องปัดเศษและจัดรูปแบบผลลัพธ์สำหรับตำแหน่งที่ตั้งปัจจุบันของผู้ใช้ (เช่น 123,456.789)
งานของฉันทั้งหมดนี้รวมอยู่ใน prettyFloat.js (สิทธิ์การใช้งาน MIT) บน GitHub: https://github.com/dperish/prettyFloat.js
ตัวอย่างการใช้งาน:
prettyFloat(1.111001, 3) // "1.111"
prettyFloat(1.111001, 4) // "1.111"
prettyFloat(1.1111001, 5) // "1.1111"
prettyFloat(1234.5678, 2) // "1234.57"
prettyFloat(1234.5678, 2, true) // "1,234.57" (en-us)
อัปเดต - สิงหาคม 2561
เบราว์เซอร์ที่ทันสมัยทั้งหมดนี้รองรับECMAScript Internationalization APIซึ่งให้การเปรียบเทียบสตริงภาษาที่ละเอียดอ่อนการจัดรูปแบบตัวเลขและการจัดรูปแบบวันที่และเวลา
let formatters = {
default: new Intl.NumberFormat(),
currency: new Intl.NumberFormat('en-US', { style: 'currency', currency: 'USD', minimumFractionDigits: 0, maximumFractionDigits: 0 }),
whole: new Intl.NumberFormat('en-US', { style: 'decimal', minimumFractionDigits: 0, maximumFractionDigits: 0 }),
oneDecimal: new Intl.NumberFormat('en-US', { style: 'decimal', minimumFractionDigits: 1, maximumFractionDigits: 1 }),
twoDecimal: new Intl.NumberFormat('en-US', { style: 'decimal', minimumFractionDigits: 2, maximumFractionDigits: 2 })
};
formatters.twoDecimal.format(1234.5678); // result: "1,234.57"
formatters.currency.format(28761232.291); // result: "$28,761,232"
สำหรับเบราว์เซอร์รุ่นเก่าคุณสามารถใช้ polyfill นี้: https://cdn.polyfill.io/v2/polyfill.min.js?features=Intl.~locale.en
1.234000 === 1.234
อืม