我试图实现本地化到我目前正在建设的网站。我的目标是使用树枝i18n扩展,因为这是我选择的模板引擎。
然而,当我添加扩展时,站点崩溃,屏幕变白,并返回500个错误代码。日志显示408超时。在我添加扩展的同一个函数中,我还添加了另一个扩展,它非常有效。我已通过Composer成功安装了扩展。(https://twig-extensions.readthedocs.io/en/latest/i18n.html)
我做错了什么?
这是我的function.php
<?php
/**
* Timber starter-theme
* https://github.com/timber/starter-theme
*
* @package WordPress
* @subpackage Timber
* @since Timber 0.1
*/
Timber::$dirname = array( 'templates');
/** Start Timber! */
class StarterSite extends Timber\Site {
/** Add timber support. */
public function __construct() {
add_theme_support( 'post-formats' );
add_theme_support( 'post-thumbnails' );
add_filter( 'timber_context', array( $this, 'add_to_context' ) );
add_filter( 'get_twig', array( $this, 'add_to_twig' ) );
add_filter('show_admin_bar', '__return_false');
define( 'WP_DEBUG', true );
parent::__construct();
}
function add_to_context( $context ) {
$context['site'] = $this;
return $context;
}
public function add_to_twig( $twig ) {
$twig->addExtension( new Twig_Extension_StringLoader() );
$twig->addExtension( new Twig_Extensions_Extension_I18n() ); // This line breaks the site
return $twig;
}
}
new StarterSite();
使用WordPress和Timber时,您不需要使用Twig的i18n扩展,如木材留档中的国际化指南所述:
Twig有自己的i18n扩展,它为您提供了{%trans%}
标记来定义可翻译的块,但是没有必要使用它,因为使用Timber,您就拥有了所需的一切。
这意味着在你的小树枝模板中,你可以使用所有你通常会使用的功能。下面是一个按钮示例。
<button>{{ __('Submit', 'my-text-domain') }}</button>
您可以像在普通WordPress主题中一样设置国际化主题。遵循主题手册中的国际化部分。
使用文本域和域路径设置style.css:
/**
* Theme Name: My Theme
* Author: Theme Author
* Text Domain: my-text-domain
* Domain Path: /languages
*/
然后,WordPress将在主题的 /languages文件夹中查找my-text-domain.pot文件。您可以使用PoeditPro生成POT文件。PoeditPro将在您的树枝文件中找到翻译。