Preamble: Speaking of toLocaleString, I have always believed that the true use is the thousandth partition, today saw other people’s code, only to find that its use is far more than the thousandth partition
1, thousandth comma (,) division
This is certainly not trivial, and it automatically supports decimals and is much simpler than regular regs
Let a = 12345600789 a.tolocalestring () //' 123456.00789 a.tolocalestring () //'123,456.008'Copy the code
It also has many applications in internationalization scenarios
// nu extended field requires numbering system, Chinese decimal a. tolocalestring (' zh-hans-CN-u-nu-hanidec ') // 'one, two, three, four, five, six hundred, eight, nine' // Arabic numerals are used in most Arabic speaking countries a.toLocaleString('ar-EG'); / / '١ ٢ ٬ ٣ ٤ ٥ ٬ ٦ ٠ ٠ ٬ ٧ ٨ ٩' / / Germany use commas as a decimal separator, divide a cycle for a one thousand - bit a.t oLocaleString (' DE - DE '); / / '12.345.600.789'Copy the code
It can also use options for parameter custom currency format conversion
let a = 12345600789 let options = { style:'currency',currency:'CNY'}; a.toLocaleString('zn-CN',options); //'¥12345,600,789.00 '¥a.toocalestring (' de-de ', {style: 'currency', currency: 'last'}) '12.345.600.789, 00 euro' limit three significant figures a.t oLocaleString (' en - IN ', {3} maximumSignificantDigits:) '12,30,00,00,000'Copy the code
2. Convert the date format
let d=new Date(); let n=d.toLocaleString(); N // '2021/12/6 PM 4:34:17' extension: let date = new date (date.UTC (2012, 11, 20, 3, 0, 0)); // If the local time zone is America/Los_Angeles // en-us displays year month day console.log(date.tolocalestring (" en-us ")) in month-day-year order; // "12/19/2012, 7:00:00pm "// EN-GB displays year month day console.log(date.tolocalestring ("en-GB")) in day-month-year order; // "20/12/2012 03:00:00" // Use year-month-day to display console.log(date.tolocalestring (" ko-kr ")); 오 : // Most Arabic countries use Arabic numeral console.log(date.tolocalestring (" ar-eg ")); // "2012.12.20.오 12:00:00" // Most Arabic countries use Arabic numeral console.log(date.tolocalestring (" ar-eg ")); // "٢٠/١٢/٢٠١٢ ١٢ :٠ :٠ ١٢ "// In Japan, The app might want to use a Japanese calendar, //2012 is the 24th year of Heisei (the year of Emperor Hito, counting from January 8, 1989 to the present) console.log(date.tolocalestring (" JA-jP-U-ca-Japanese ")); // "24/12/20 12:00:00" // When requesting a language that may not be supported, such as Bali (BAN), if there is an alternate language Indonesian (ID), // Indonesian (id) console.log(date.tolocalestring (["ban", "id"])); / / "20/12/2012 11.00.00"Copy the code
You can also use the options parameter to define the display type format
let date = new Date(Date.UTC(2012, 11, 20, 3, 0, 0)); // Request parameters (options) contain the parameter weekday and the value is long let options = {weekday: "long", year: "numeric", month: "long", day: "numeric"}; console.log(date.toLocaleString("de-DE", options)); TimeZone = "UTC"; //"Donnerstag, 20.dezember 2012" // An application uses universal standard Time (UTC), and UTC uses a short name (short) display options. TimeZone = "UTC"; options.timeZoneName = "short"; // If you don't write this line, it will still display universal standard time; But the GMT three letters will not display console.log(date.tolocalestring (" en-us ", options)); // "Thursday, December 20, 2012, GMT" // Console. log(date.tolocalestring (" en-us ", {hour12: false})); 12/19/2012 19:00:00 "/ /"Copy the code
3. Arrays are converted to strings
var arr = new Array(3)
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"
// George, John, Thomas
Copy the code
4. Convert to percentages
Convert numbers to percentages using toLocaleString() let a = 1; console.log(a.toLocaleString('zh',{style:'percent'})) // 100% let b = 2; Console. log(b.tolocalestring ('zh',{style:'percent'})) // 200% let c = 0.9; console.log(c.toLocaleString('zh',{style:'percent'})) //90%Copy the code
compatibility
Temporarily found so, there will be new updates.
You are welcome to add 👏