溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Laravel中如何使用本地化模塊

發(fā)布時(shí)間:2021-07-19 14:38:45 來源:億速云 閱讀:177 作者:Leah 欄目:開發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)Laravel中如何使用本地化模塊,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

模塊組成

下圖展示了本地化模塊各個(gè)文件的關(guān)系,并進(jìn)行簡要說明;

Laravel中如何使用本地化模塊

  • TranslationServiceProvider
     本地化模塊的服務(wù)提供者,既是一個(gè)模塊的入口,也是與IOC容器交互的中心;注冊翻譯器實(shí)例translation.loader,注冊翻譯管理實(shí)例translator,并聲明延遲加載服務(wù);

  • Translator
     翻譯管理類;

  • MessageSelector
     消息過濾器,通過判斷復(fù)數(shù)值來選擇合適的消息;比如消息內(nèi)容是這樣的{0}沒有|[1,19]一些|[20,*]很多,我們傳的數(shù)字是 18,那么最后選擇的消息就是"一些";

  • LoaderInterface
     翻譯器接口;聲明了三個(gè)方法load,addNamespace,namespaces;

  • FileLoader
     繼承了LoaderInterface,從文件獲取本地化資源數(shù)據(jù);

  • ArrayLoader
     繼承了LoaderInterface,在內(nèi)存用數(shù)組維護(hù)本地化資源數(shù)據(jù);

配置說明

在config配置目錄下和本模塊有關(guān)的參數(shù)只有app.php文件中的locale和fallback_locale;

locale表示默認(rèn)本地化語言是什么,這樣會(huì)優(yōu)先從該語言資源目錄中獲取翻譯(轉(zhuǎn)換)內(nèi)容;
如果locale表示的語言不存在,則使用fallback_locale這個(gè)備用語言;

筆者的locale是zh_CN,fallback_locale是en;

功能介紹

全局的語言資源目錄在項(xiàng)目的resources/lang下,每個(gè)子目錄分別以語言為名,比如en、zh_CN等;

另外一些子目錄是命名空間為名,是對(duì)第三方加載庫資源文件的補(bǔ)充替換;

有可能還存在en.json、zh_CN這類Json文件,項(xiàng)目有時(shí)候會(huì)從Json文件讀取數(shù)據(jù),這些數(shù)據(jù)均來自于這個(gè)已存在的Json文件;

翻譯全局語言資源

筆者的語言資源根目錄resources/lang下有zh_CN/validation.php,內(nèi)容如下

<?php
return [
 'accepted'  => ':attribute 必須接受。',
 'active_url'  => ':attribute 不是一個(gè)有效的網(wǎng)址。',
 'after'  => ':attribute 必須是一個(gè)在 :date 之后的日期。',
 ......
];

通過調(diào)用代碼

app('translator')->trans('validation.accepted', ['attribute' => '用戶名'])

或者全局幫助函數(shù)trans

trans('validation.accepted', ['attribute' => '用戶名'])

輸出 "用戶名 必須接受。";

調(diào)用過程如下:

  • 解析鍵名:將鍵名進(jìn)行解析成數(shù)組 ($namespace = '*', $group = 'validation', $item = 'accepted');namespace為*,表示在全局命名空間下;group,組,其實(shí)就是文件名,一個(gè)文件為一組;item是元素的意思;

  • 獲取語言數(shù)組: 這里的$locale為null,所以返回的是默認(rèn)與備用語言組成的數(shù)組,也就是['zh_CN', 'en'];并進(jìn)行for循環(huán),進(jìn)入語言資源目錄中尋找需要的元素值,如果找到,即 break;

  • 加載資源:因?yàn)槊臻g為*,所以定位資源根目錄為resources/lang;語言為zh_CN,所以子目錄為zh_CN;group名為validation,這時(shí)就把resources/lang/zh_CN/validation.php文件中的所有內(nèi)容都加載進(jìn)內(nèi)存中,并進(jìn)行保存 $this->loaded[$namespace][$group][$locale] = $lines;

  • 獲取資源,并替換參數(shù):通過Arr::get方法從$this->loaded[$namespace][$group][$locale]中獲取元素值:attribute 必須接受。;此時(shí),參數(shù)數(shù)組為不空,循環(huán)替換,得到結(jié)果"用戶名 必須接受。";

翻譯帶命名空間的語言資源

筆者在語言資源根目錄resource/lang下,創(chuàng)建vendor/Faker/Provider/zh_CN/Internet.php文件,內(nèi)容如下:

<?php
return [
 'message' => 'hello, Faker/Provider',
 ......
];

同時(shí),手動(dòng)在Translator中注冊第三方插件(也就是帶命名空間)的資源根目錄位置;

app('translator')->addNamespace('Faker/Provider', base_path('vendor/xx/resource/lang'))

現(xiàn)在,獲取帶命名空間的資源;

trans('Faker/Provider::Internet.message');

輸出 'hello, Faker/Provider';

調(diào)用過程如下:

  • 解析鍵名:將鍵名進(jìn)行解析成數(shù)組 ($namespace = 'Faker/Provider', $group = 'Internet', $item = 'message');

  • 獲取語言數(shù)組: 這里的$locale為null,所以返回的是默認(rèn)與備用語言組成的數(shù)組,也就是['zh_CN', 'en'];并進(jìn)行for循環(huán),進(jìn)入語言資源目錄中尋找需要的元素值,如果找到,即 break;

  • 加載資源:因?yàn)槊臻g為Faker/Provider,此時(shí)會(huì)分兩步;第一步讀取第三方插件資源庫下的信息,這時(shí)讀取命名空間注冊的根目錄為base_path('vendor/xx/resource/lang'),就讀取base_path('vendor/xx/resource/lang')/zh_CN/Internet.php內(nèi)容,文件不存在,返回空數(shù)組;第二步讀取全局語言資源,進(jìn)行補(bǔ)充,也就是讀取base_path('resource/lang/vendor/Faker/Provider')/zh_CN/Internet.php; 最后進(jìn)行保存 $this->loaded[$namespace][$group][$locale] = $lines;

  • 獲取資源,并替換參數(shù):通過Arr::get方法從$this->loaded[$namespace][$group][$locale]中獲取元素值" hello, Faker/Provider";此時(shí),參數(shù)數(shù)組為空,直接返回結(jié)果 "hello, Faker/Provider";

翻譯Json文件中的資源

筆者在語言資源根目錄resource/lang下,創(chuàng)建zh_CN.json文件,內(nèi)容如下:

{
 "name": "zh_CN.json",
 "place": "../resources/lang/zh_CN.json"
}

現(xiàn)在,獲取Json文件中的name值;

trans('*.name')

輸出 "zh_CN.json";

調(diào)用過程如下:

  • 解析鍵名:將鍵名進(jìn)行解析成數(shù)組 ($namespace = '*', $group = '*', $item = 'name');

  • 獲取語言數(shù)組: 這里的$locale為null,所以返回的是默認(rèn)與備用語言組成的數(shù)組,也就是['zh_CN', 'en'];并進(jìn)行for循環(huán),進(jìn)入語言資源目錄中尋找需要的元素值,如果找到,即 break;

  • 加載資源:因?yàn)槊臻g為*,且組也為*,這時(shí)會(huì)讀取語言根目錄下,名字為語言值的Json文件;此時(shí)會(huì)讀取resource/lang/zh_CN.json,將讀取的內(nèi)容,進(jìn)行保存 $this->loaded[$namespace][$group][$locale] = $lines;

  • 獲取資源,并替換參數(shù):通過Arr::get方法從$this->loaded[$namespace][$group][$locale]中獲取元素值"zh_CN.json";此時(shí),參數(shù)數(shù)組為空,直接返回結(jié)果 "zh_CN.json";

運(yùn)行時(shí)綁定資源

資源的內(nèi)容除了放在文件中,用到的時(shí)候在讀取,也可以在項(xiàng)目運(yùn)行時(shí),存放;

以resources/lang/zh_CN/validation.php為例,現(xiàn)在想要在運(yùn)行時(shí),給這個(gè)組添加一個(gè)新的元素叫 extra,需要指定放在哪個(gè)語言下,可以這樣寫

app('translator')->addLines(array('validation.extra' => '測試添加額外數(shù)據(jù)'), 'zh_CN');

現(xiàn)在可以獲取這個(gè)新添加的元素值

trans('validation.extra')

復(fù)數(shù)資源過濾

筆者通過 運(yùn)行時(shí)綁定資源 添加一條翻譯內(nèi)容:

app('translator')->addLines(array('validation.extra' => '{0}沒有|[1,19]一些|[20,*]很多'), 'zh_CN');

如果通過trans('validation.extra') ,獲取的就是整條翻譯內(nèi)容,不是我們所期望的;用choice方法:

app('translator')->choice('validation.extra', 0) 得到 沒有;

app('translator')->choice('validation.extra', 18) 得到 一些;

app('translator')->choice('validation.extra', 20) 得到 很多;

可以將app('translator')->choice(...)簡寫成全局幫助函數(shù)trans_choice(...);

上述就是小編為大家分享的Laravel中如何使用本地化模塊了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI