国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - 如何優(yōu)雅的在一個js文件里配置多語言(i18n),求探討思路

瀏覽:103日期:2023-03-21 15:00:26

問題描述

我搜了搜資料,發(fā)現(xiàn)大多數(shù)是不同語言的js文件分開做,然后根據(jù)用戶語言環(huán)境去加載對應(yīng)的js文件。

但是我現(xiàn)在因為使用場景限制,最好是在一個js文件里完成。我現(xiàn)在打算支持3種語言(中文、日文、英文),而且輸出文字的地方也比較多,可能有上百條,中間也經(jīng)常要拼接變量。

使用場景示例:

var result=10;document.body.innerHTML='一共有'+result+'個結(jié)果';

現(xiàn)在我的思路有兩種,一種是把語言文字保存到一個變量里;一種是把文字寫在原地,形式為數(shù)組,然后使用下標(biāo)調(diào)用。

思路1:

// 方式1:判斷語言后確定唯一的結(jié)果。有點割裂,而且在使用時只能看到屬性名,影響思路// {w1}是占位符,每個配置寫了多遍是為了模擬數(shù)量多的時候的情景var lang={};if () { // 判斷為中文 lang.tip1='一共有{w1}個結(jié)果'; // lang.tip2='一共有{w1}個結(jié)果'; // lang.tip3='一共有{w1}個結(jié)果'; // lang.tip4='一共有{w1}個結(jié)果'; // lang.tip5='一共有{w1}個結(jié)果';}else if(){ // 判斷為日文 lang.tip1='{w1}の結(jié)果の合計'; // lang.tip2='{w1}の結(jié)果の合計'; // lang.tip3='{w1}の結(jié)果の合計'; // lang.tip4='{w1}の結(jié)果の合計'; // lang.tip5='{w1}の結(jié)果の合計';}else if(){ // 判斷為英文 lang.tip1='There is a total of {w1} result'; // lang.tip2='There is a total of {w1} result'; // lang.tip3='There is a total of {w1} result'; // lang.tip4='There is a total of {w1} result'; // lang.tip5='There is a total of {w1} result';}var result=10;document.body.innerHTML=lang.tip1.replace('{w1}',result);思路2:

// 方式2:判斷語言后只做個下標(biāo),文字寫在原地方。這樣使用時可以知道這里寫的是什么,但似乎比較亂var lang;if () { // 判斷為中文 lang=0;}else if(){ // 判斷為日文 lang=1;}else if(){ // 判斷為英文 lang=2;}var result=10;document.body.innerHTML=['一共有{w1}個結(jié)果','{w1}の結(jié)果の合計','There is a total of {w1} result'][lang].replace('{w1}',result);

其實第一種方法形式上較為優(yōu)雅,不過我個人傾向于第二種,主要是我看代碼的時候知道這里寫的是什么。如果通過變量名判斷內(nèi)容的話則比較麻煩(主要是條數(shù)太多,雖然我實際使用的話要把變量名做語義化處理,但能簡短、準(zhǔn)確描述出內(nèi)容的情況也不多)。

請問大家有其他思路或解決辦法嗎?

問題解答

回答1:

你的意思大概是想把所有文字都翻譯,但由于語法結(jié)構(gòu)問題變量的位置是未知的不知道怎么解決是吧?思路的話其實你可以參考模板渲染的思路.我打個比方

var language = { ’hello’: [’hello,{val}!’,’{val},コン!’ ]};var lang = 0; // 當(dāng)前英文function translate (msgVariable, data, msg) { if (msg !== undefined) language[msgVariable].push(msg); return language[msgVariable][lang].replace(’{val}’, data);}var data = ’張三’;var msg = translate(’hello’, data, ’你好,{val}!’);回答2:

比如這樣?

var hello = { 'cn' : '哈嘍', 'jp' : 'こんにちは', 'en' : 'f**k you'};//在頁面初始化的時候判斷當(dāng)前的環(huán)境,然后直接設(shè)定key值就可以,比如說我現(xiàn)在是日語var lang = 'jp';console.log(hello[lang]);//拓展的話往對象里面加值就行了,比如說加韓文var hello = { 'cn' : '哈嘍', 'jp' : 'こんにちは', 'en' : 'f**k you', 'kr' : '為何不洗澡思密達'};lang = 'kr';console.log(hello[lang]);回答3:

您的問題算是i18n/L10n的範(fàn)圍,或許可以找到像

jQuery.i18n

JavaScript I18n And L10n等等的國際化和本地化的javascript 庫。第一個庫還是維基媒體搞出來的,很有參考價值。

其他基本的i18n/L10n內(nèi)容及庫,別錯過

Unicode CLDR如簡中語言表

ICU library

本人對i18n/L10n的在中國的發(fā)展很感興趣,一起切磋成長。

標(biāo)簽: JavaScript
主站蜘蛛池模板: 宁陵县| 隆德县| 昭苏县| 进贤县| 枝江市| 黄陵县| 巴楚县| 丽水市| 郑州市| 梓潼县| 麻栗坡县| 防城港市| 河西区| 博兴县| 泰宁县| 南宁市| 敦煌市| 陵水| 青田县| 桐城市| 措勤县| 雷山县| 喀什市| 津南区| 舞钢市| 安徽省| 临沭县| 攀枝花市| 灵丘县| 新竹县| 龙岩市| 收藏| 庐江县| 同心县| 广昌县| 瑞昌市| 九江县| 木里| 苏尼特右旗| 吉林省| 杂多县|