溫馨提示×

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

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

如何理解WordPress的JavaScript本地化

發(fā)布時(shí)間:2021-11-17 16:55:30 來源:億速云 閱讀:146 作者:柒染 欄目:web開發(fā)

本篇文章為大家展示了如何理解WordPress的JavaScript本地化,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

WordPress 升級(jí)到 3.1 之后, 如果主題支持 wp_head() 方法, 將在頁面加載一個(gè)名為 l10n.js 的文件, 這是為 JavaScript 本地化提供的工具庫. 目前對(duì)大多數(shù)人來說是一個(gè)無用的功能, 甚至有人認(rèn)為這是 WordPress 卑鄙地偷偷地在頁面上埋了一個(gè)扯淡的腳本, 所以網(wǎng)上能找到的都是如何卸載腳本的方法.

在我們卸載之前, 是不是應(yīng)該先了解一下這是怎樣的一個(gè)功能, 添加腳本的意圖是什么? 小編將說明 l10n.js 腳本存在的意義, 本地化腳本的使用方法和對(duì)其未來的展望.

<script type='text/javascript' src='{ROOT DIR}/wp-includes/js/l10n.js?ver=20101110'></script>

i18n 和 l10n

i18n[1] 和 l10n[2] 是 IT 領(lǐng)域常用的縮寫術(shù)語, 分別是國際化和本地化的意思. i18n 指應(yīng)用程序能夠?yàn)椴煌膰液驼Z言環(huán)境的用戶群體提供本地化的服務(wù), 而 l10n 則是在用戶使用環(huán)境實(shí)現(xiàn)本地化特性, 國際化和本地化泛指語言環(huán)境的多語言實(shí)現(xiàn). 如: WordPress 是一個(gè)支持國際化的程序, 只要提供對(duì)應(yīng)國家語言包并制定國家代號(hào), 就能替換整個(gè)網(wǎng)站的語言環(huán)境.

JavaScript 本地化

如前面的例子, WordPress 一直支持國際化, 并提供 _e() 和 __() 兩個(gè) PHP 方法對(duì)程序進(jìn)行本地化. 但隨著前端 JavaScript 應(yīng)用越來越多, 后端的國際化已經(jīng)滿足不了所有需求, 有必要引入 JavaScript 的國際化和本地化.

若你使用的主題支持 wp_head() 方法, 將在頁面加載 l10n.js 文件, 而且用戶可以通過簡單的代碼向頁面注入本地化資源. l10n.js 是一個(gè) JavaScript 本地化的工具庫, 包含 convertEntities() 方法, 可以將 HTML 對(duì)象還原成原來的值, 所以它會(huì)在所有注入的 JavaScript 腳本和本地化資源之前載入.

使用的方法

我們可以為每一個(gè)要載入的 JavaScript 文件定義本地化資源. 實(shí)現(xiàn)代碼如下[3]:

// 必須先載入一個(gè) Javascript 文件  wp_enqueue_script('some_handle', '/some_javascript.js');  // 組裝本地化數(shù)據(jù), 使用 __() 制作本地化內(nèi)容  $data = array( 'some_string' => __( 'Some string to translate' ) );  // 加載本地化腳本. 這里必須指定一個(gè)需要載入的 JavaScript 文件.  wp_localize_script( 'some_handle', 'object_name', $data );

執(zhí)行后將在頁面上生成代碼如下:

/* <![CDATA[ */ var object_name = {  some_string: "Some string to translate" };  /* ]]> */ <script type='text/javascript' src='{ROOT DIR}/some_javascript.js?ver=3.1'></script>

本地化資源會(huì)在指定腳本之前載入和定義. 其中 {ROOT DIR} 是網(wǎng)站的根目錄.

此時(shí)如果我們可以通過以下代碼進(jìn)行測(cè)試:

alert(object_name.some_string); // 彈出對(duì)話框, 顯示 'Some string to translate'

利弊和應(yīng)用場(chǎng)合

好處前面說了很多, 可以方便地進(jìn)行前端本地化 (需要后端 PHP 配合). 缺點(diǎn)也很明顯, 會(huì)在每次頁面加載時(shí)計(jì)算本地化資源, 并且載入大量 JavaScript 代碼, 增加系統(tǒng)負(fù)擔(dān)和延長頁面加載時(shí)間.

JavaScript 本地化是 WordPress 主題和插件制作中讓人較為煩惱的地方, 一些插件開發(fā)者會(huì)在頁面上自行定義 l10n 對(duì)象, 可以參考 WP-RecentComments 插件的做法. WordPress 這次強(qiáng)行引入, 很可能會(huì)被主題和插件開發(fā)者廣泛應(yīng)用. 也就是說, 不久的將來你未必敢卸載掉它, 否則某些插件將運(yùn)行不了.

卸載和恢復(fù)的方法

雖說 l10n.js 文件很小, 好歹會(huì)發(fā)出一個(gè)請(qǐng)求, 如果你真的認(rèn)為沒用, 可以在 functions.php 中添加以下代碼將它卸載掉.

wp_deregister_script('l10n');

如函數(shù)名, 這個(gè)方法不是禁用, 而是注銷. 也就是說, 一旦你注銷就沒有了, 就算刪除這段代碼也不會(huì)還原. 如果在注銷后希望回復(fù)需要使用以下方法:

wp_register_script('l10n');

上述內(nèi)容就是如何理解WordPress的JavaScript本地化,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

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

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎ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