日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JS的本地化

發布時間:2023/12/18 javascript 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JS的本地化 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本地化中主要的是日期、貨幣、數字等相關的顯示。很多文章介紹一些控件如moment.js, format.js等來做這些事情,實際上在新的JS規范中已經考慮了這些情況,并且提供了相關的函數等,完全沒有必要使用第三方控件。詳細內容請參考MDN中的說明:

https://developer.mozilla.org/en-US/docs/Web/JavaScript

下面簡單介紹一下使用方法

日期本地化

最簡單的方法就是使用 toLocaleXxx的接口,包括下面本個接口,其中localeId可以不傳,使用瀏覽器本地的格式

.toLocaleTimeString(localeId);? ? // h:m:s
.toLocaleDateString(localeId);? ? // Y:M:D

.toLocaleString(localeId);????????? ? // Y:M:D h:m:s

上面的三個接口的缺點是對于只有一位數字時沒有前導0。如果需要0對齊,則要用到Intl.DateTimeFormat,設置option相關的屬性值,主要有"numeric"(不帶前導0),?"2-digit"(帶前導0)。下面是基于MDN中的樣例代碼稍做修改后的樣子,主要是為了說明前導0的使用

var date = new Date(Date.UTC(2018, 5, 20, 3, 0, 0)); // sometimes even the US needs 24-hour time options = {year: 'numeric', month: '2-digit', day: 'numeric',hour: 'numeric', minute: 'numeric', second: 'numeric',hour12: false,了// 使用24小時制timeZone: 'America/Los_Angeles' }; console.log(new Intl.DateTimeFormat('en-US', options).format(date)); // → "05/19/2018, 19:00:00"

數字本地化

數字本地化和日期類似,對簡單的使用可以通過 Number.toLocaleString完成,如

(new Number(123456.789)).toLocaleString('zh-CN');

對于更靈活的用法可以使用 Intl.NumberFormat來完成

貨幣本地化

貨幣也屬于數字,因此被合并到Intl.NumberFormat中通過兩個屬性style: 'currency', currency: 'XXX' 完成。但顯示的貨幣符號不太合適,如美元一般用 $,但顯示為USA,人民幣使用¥,但顯示為RMB


瀏覽器兼容問題

目前流行的主要瀏覽在新版本上都是支持的,包括IE11, Edge, chrome, firefox


結束語

做為一個項目可以對這些進行簡單封裝在使用,讓每個頁面自己寫上面的代碼是不合適的。有需要的可以留言

最后想說一點,隨著JS的廣泛應用,很多在10年前或者5年前都需要自己寫的JS代碼,瀏覽器現在都已經內置,我們不需要再引入第三方插件了。必竟瀏覽器內置的代碼要比第三方插件在穩定性和性能上都要好一些。



總結

以上是生活随笔為你收集整理的JS的本地化的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。