如果你的WordPress主题要提交到WordPress官方主题库,使用者来自世界各地的多种语言,那么,你就要让你的WordPress主题支持语言本地化,方便使用者进行语言翻译和制作语言包。

让WordPress主题支持语言本地化,主要流程为:让主题开启语言本地化功能,然后使用符合WordPress API 规范的写法来撰写需要翻译的内容,接着使用 poedit 生成语言包。下面倡萌将进行详细讲解。

让主题支持语言包

在主题的 functions.php 文件添加下面的代码:

  1. add_action('after_setup_theme', 'my_theme_setup');
  2. function my_theme_setup(){
  3.     load_theme_textdomain('wpdaxue', get_template_directory() . '/languages');
  4. }

该代码是通过 load_theme_textdomain() 函数来定义主题的语言路径,其中包含了两个参数,第一个“wpdaxue”是 textdomain ,第二个“get_template_directory() . '/languages' ”则指明主题的语言存放路径为 当前主题的 languages 目录。只要将语言包存放在这个目录,就可以生效。

规范编译要翻译的内容

要让你的主题的文本内容支持自动翻译,需要你做好规范符合 WordPress API 的书写。WordPress常用下面几个函数来包裹需要翻译的内容:

  • __()
  • _e()
  • _x()
  • _ex()
  • _n()

倡萌已经介绍过《WordPress翻译中 __()、_e()、_x、_ex 和 _n 的用法及区别》,但是在实际使用中,我们还需要注意以上函数的末位参数 。也就是在上一步中,我们通过 load_theme_textdomain() 函数定义了第一个参数 $domain 为“wpdaxue”,这个参数都需要添加到 __() 等函数中作为末位参数,它是用来检索被翻译字符串的唯一标识符。例如:

  1. <?php  
  2. the_content( __( 'Click here to read more','wpdaxue' ) ); 
  3. ?>

如果去掉上面代码 __() 的末位参数‘wpdaxue’,对应的 'Click here to read more' 的翻译内容就没办法正常加载。

使用 POEdit 制作语言包

POEdit 是一款非常有用的语言包制作软件,你可以在 POEdit 官方下载,安装好以后,就是中文界面了。下面就简单演示一下操作过程。

新建编目

点击 文件 > 新建编目,会出现如下界面:

1.在”翻译属性”中按照下面的范例添加信息:

需要注意的是,“语言”就是输出语言的简码,比如简体中文为 zh_CN (注意大小写),然后字符集一般选择 UTF-8,复数形式一般填 nplurals=2; plural=(n!=1); 即可。

2.切换到“源路径”,由于前面我们创建的语言包路径为当前主题的 languages 目录,所以这里我们添加相对路径 ../ 即可,如下图:

3.添加“源关键字”,这个关键字就是要识别上面的几个翻译函数。

需要注意的是,_n、_x 和 _ex 这三个函数要添加对应的参数才能实现其功能,建议对应的写法为

  • __
  • _e
  • _n:1,2
  • _x:1,2c
  • _ex:1,2c

填写完以后,点击“确认”,就创建好了编目。

导入需要翻译的字符串

点击“更新”按钮,如果你前面的步骤没有出错的话,就会自动搜索主题文件中需要翻译的条目,如下图:

翻译字符串

翻译完以后,将语言包保存到主题的语言目录 languages 中,这里特别要注意语言包的命名。它是使用 Gettext 代码来命名的,比如中文的 Gettext 语言代码为 zh ,国别代码为 CN,所以最终保存的简体中文语言包为 zh_CN.po,POEdit 会自动生成一个名为 zh_CN.mo 的文件。

po 和 mo 的最直接的区别在于:po文件是给人看的,也是可以直接通过 POEdit 编辑的,mo 文件则是给服务器识别的,是用来显示翻译内容所必需的。也就是说,你的主题语言目录中,可以没有po文件,但是必须有mo文件,否则服务器就没办法加载翻译!

你可以通过下面的链接了解更多 Gettext 代码:

  • Gettext 语言代码
  • Gettext 国别代码

让WordPress识别语言包

通过上面的步骤,我们已经创建好了语言包,那么WordPress如何才能识别语言包?打开WordPress根目录下的 wp-config.php 文件,找到 WPLANG,如果这里填入的是 zh_CN ,说明你使用的是简体中文版本的 WordPress,那么主题也会自动调用简体中文语言包 zh_CN.mo 。

  1. /**
  2.  * WordPress 语言设置,中文版本默认为中文。
  3.  *
  4.  * 本项设定能够让 WordPress 显示您需要的语言。
  5.  * wp-content/languages 内应放置同名的 .mo 语言文件。
  6.  * 要使用 WordPress 简体中文界面,只需填入 zh_CN。
  7.  */
  8. define('WPLANG', 'zh_CN');

小结

在整个过程中,工作量最大的就是 “规范编译要翻译的内容”这个步骤,你必须有耐心,仔细地规范代码。熟悉 __()、_e()、_x、_ex 和 _n 的不同用法是难点所在。

黄聪:让WordPress主题支持语言本地化(使用poedit软件实现中文翻译功能)相关推荐

  1. 黄聪:《跟黄聪学WordPress主题开发》

    又一个作品完成!<跟黄聪学Wordpress主题开发>,国内最好的Wordpress主题模版开发视频教程!! 目录预览: WordPress官方源文件层式结构讲解 WordPress数据库 ...

  2. 黄聪:《跟黄聪学WordPress插件开发》

    续<跟黄聪学WordPress主题开发>之后,又一个作品完成!<跟黄聪学Wordpress插件开发>,国内最好的Wordpress插件开发视频教程!! 目录预览: WordPr ...

  3. 黄聪:wordpress教程

    又一个作品完成!<跟黄聪学Wordpress主题开发>,国内最好的Wordpress主题模版开发视频教程!! 目录预览: WordPress官方源文件层式结构讲解 WordPress数据库 ...

  4. 黄聪:wordpress如何开启文章格式post format

    发现很多"古老"的WordPress主题使用量非常大,虽然部分也在随着WordPress版本的升级而"升级",只不过是修复了bug而已,wordpress的新特 ...

  5. 让你的WordPress主题支持自定义菜单

    WordPress 3+以后的版本已经支持自定义菜单功能,如果你的主题还不能支持这个功能话,我敢说你的主题Out啦,是不是想再In进来?那就认真继续阅读,让你的WordPress主题支持自定义菜单功能 ...

  6. 黄聪:wordpress后台加载ajax.googleapis.com导致打开速度很慢的解决方案

    黄聪:wordpress后台加载ajax.googleapis.com导致打开速度很慢的解决方案 参考文章: (1)黄聪:wordpress后台加载ajax.googleapis.com导致打开速度很 ...

  7. 黄聪:wordpress调用函数大全

    本文转载自: https://www.cnblogs.com/huangcong/archive/2011/07/04/2097764.html 作者:huangcong 转载请注明该声明. Word ...

  8. 黄聪:C#编写的Word操作类,有换页,添加表格,文本功能

    最近要帮老师做个工资管理系统,需要自动生成Word. 就上网找了个Word操作类,再做了点修改,下面公布一下自己的代码: using System; using System.Collections. ...

  9. 黄聪:wordpress源码解析-目录结构-文件调用关系(转)

    Wordpress是一个单入口的文件,所有的前端处理都必须经过index.php,这是通过修改web服务器的rewrite规则来实现的.这种做法的好处是显而易见的,这样URL更好看,不必为每一个url ...

  10. 黄聪:wordpress文章同步发布到网易、天涯、新浪博客、百度空间插件

    新浪博客,网易博客,百度空间,天涯博客都是权重很高的第三方博客平台.如果能保持更新,有助于提升主站权重.有了博客同步插件,直接在wordpress 后台设置一下,wordpress 自动把更新的日志同 ...

最新文章

  1. 【Stage3D学习笔记续】山寨Starling(八):核心优化(批处理)的实现
  2. PHP中上传文件文件名乱码
  3. 商品评价 - 实现分页
  4. Managed keyedState中的ValueStateDescriptor与MapStateDescriptor
  5. java中bean的定义有哪些_详解Java的Spring框架中bean的定义以及生命周期
  6. Android开发系列之屏幕密度和单位转换
  7. stm32读取目标芯片_使用stm32驱动RC522读IC卡(代码留言邮箱)
  8. 环信SDK 踩坑记webIM篇(一)
  9. 原来热加载如此简单,手动写一个 Java 热加载吧
  10. 信息学奥赛一本通(2021:【例4.6】最大公约数)
  11. linux应用程序原理,LINUX原理及应用:第15章 XWindow及Genie应用程序
  12. win10 windows按钮右键没有命令提示符
  13. ubuntu 自动挂载工具_Ubuntu自动挂载分区
  14. true是不是python保留字_Python基本语法--关键字和保留字篇
  15. 野指针   悬垂指针   迷途指针
  16. stm32f103不同系列之间的代码移植
  17. SQL连接表(内连接、左连接、右连接、交叉连接、全外连接)
  18. 云播 Android,云播放(Air Playit)android版
  19. Python-opencv 图片颜色域的识别选取
  20. xposed修改手机屏幕分辨率

热门文章

  1. java opencv 之车辆识别
  2. 模版之家全站静态模板免费下载
  3. GM620光猫telnet获取pppoe密码
  4. python一般用什么平台好_python哪几个平台好用
  5. win7 计算机定时关机脚本,Win7制作定时关机bat脚本|Win7定时关机程序脚本
  6. html弹窗代码大全定时弹窗,js点击弹窗弹出表单框代码
  7. 在武汉火车站转车需要出现吗_武汉打造40分钟“高铁中转站” 无需出站可换乘...
  8. Android中铃声总结源码
  9. 等保测评--网络安全等级保护定级指南
  10. MAC(多路访问控制)协议