此插件用于獲取有關(guān)用戶語(yǔ)言區(qū)域語(yǔ)言,日期和時(shí)區(qū),貨幣等的信息。
打開(kāi)命令提示符并通過(guò)鍵入以下代碼安裝插件。
C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-globalization
我們將向 index.html 添加幾個(gè)按鈕,以便能夠調(diào)用我們稍后將創(chuàng)建的不同方法。
<button id = "getLanguage">LANGUAGE</button> <button id = "getLocaleName">LOCALE NAME</button> <button id = "getDate">DATE</button> <button id = "getCurrency">CURRENCY</button>
事件監(jiān)聽(tīng)器將被添加到 index.js 文件中的 getDeviceReady 函數(shù)中,以確保我們的應(yīng)用程序和Cordova在我們開(kāi)始使用它之前加載。
document.getElementById("getLanguage").addEventListener("click", getLanguage); document.getElementById("getLocaleName").addEventListener("click", getLocaleName); document.getElementById("getDate").addEventListener("click", getDate); document.getElementById("getCurrency").addEventListener("click", getCurrency);
我們使用的第一個(gè)函數(shù)返回客戶端設(shè)備的BCP 47語(yǔ)言標(biāo)簽。我們將使用 getPreferredLanguage 方法。該函數(shù)有兩個(gè)參數(shù) onSuccess 和 onError 。我們?cè)?strong> index.js 中添加此函數(shù)。
function getLanguage() { navigator.globalization.getPreferredLanguage(onSuccess, onError); function onSuccess(language) { alert('language: ' + language.value + '\n'); } function onError(){ alert('Error getting language'); } }
一旦按下 LANGUAGE 按鈕,警報(bào)將顯示在屏幕上。
此函數(shù)返回客戶端區(qū)域設(shè)置的BCP 47標(biāo)簽。 此函數(shù)與我們之前創(chuàng)建的函數(shù)類似。 唯一的區(qū)別是,我們這次使用 getLocaleName 方法。
function getLocaleName() { navigator.globalization.getLocaleName(onSuccess, onError); function onSuccess(locale) { alert('locale: ' + locale.value); } function onError(){ alert('Error getting locale'); } }
當(dāng)我們點(diǎn)擊 LOCALE 按鈕時(shí),提醒將顯示我們的區(qū)域設(shè)置標(biāo)簽。
此功能用于根據(jù)客戶端的區(qū)域設(shè)置和時(shí)區(qū)設(shè)置返回日期。date 參數(shù)是當(dāng)前日期, options 參數(shù)是可選的。
function getDate() { var date = new Date(); var options = { formatLength:'short', selector:'date and time' } navigator.globalization.dateToString(date, onSuccess, onError, options); function onSuccess(date) { alert('date: ' + date.value); } function onError(){ alert('Error getting dateString'); } }
我們現(xiàn)在可以運(yùn)行應(yīng)用程序,然后按 DATE 按鈕查看當(dāng)前日期。
我們將顯示的最后一個(gè)功能是根據(jù)客戶端的設(shè)備設(shè)置和ISO 4217貨幣代碼返回貨幣值。你可以看到這個(gè)概念是一樣的。
function getCurrency() { var currencyCode = 'EUR'; navigator.globalization.getCurrencyPattern(currencyCode, onSuccess, onError); function onSuccess(pattern) { alert('pattern: ' + pattern.pattern + '\n' + 'code: ' + pattern.code + '\n' + 'fraction: ' + pattern.fraction + '\n' + 'rounding: ' + pattern.rounding + '\n' + 'decimal: ' + pattern.decimal + '\n' + 'grouping: ' + pattern.grouping); } function onError(){ alert('Error getting pattern'); } }
CURRENCY 按鈕將觸發(fā)警報(bào),顯示用戶的貨幣模式。
此插件提供其他方法。你可以看到下面的表中所有的。
方法 | 參數(shù) | 細(xì)節(jié) |
---|---|---|
getPreferredLanguage | onSuccess,onError | 返回客戶端當(dāng)前的語(yǔ)言。 |
getLocaleName | onSuccess,onError | 返回客戶端的當(dāng)前語(yǔ)言環(huán)境設(shè)置。 |
dateToString | 日期,onSuccess,onError,選項(xiàng) | 根據(jù)客戶的區(qū)域設(shè)置和時(shí)區(qū)返回日期。 |
stringToDate | dateString,onSuccess,onError,options | 根據(jù)客戶端的設(shè)置解析日期。 |
getCurrencyPattern | currencyCode,onSuccess,onError | 返回客戶的貨幣模式。 |
getDatePattern | onSuccess,onError,options | 返回客戶端的日期模式。 |
getDateNames | onSuccess,onError,options | 根據(jù)客戶端的設(shè)置返回月,周或天的名稱數(shù)組。 |
isDayLightSavingsTime | date,successCallback,errorCallback | 用于根據(jù)客戶端的時(shí)區(qū)和日歷確定夏令時(shí)是否活動(dòng)。 |
getFirstDayOfWeek | onSuccess,onError | 根據(jù)客戶端設(shè)置返回一周的第一天。 |
numberToString | number,onSuccess,onError,options | 根據(jù)客戶端的設(shè)置返回number。 |
stringToNumber | string,onSuccess,onError,options | 根據(jù)客戶端的設(shè)置解析一個(gè)數(shù)字。 |
getNumberPattern | onSuccess,onError,options | 根據(jù)客戶端的設(shè)置返回?cái)?shù)字模式。 |
更多建議: