Home > Backend Development > PHP Tutorial > Yii2中做中英文网站

Yii2中做中英文网站

WBOY
Release: 2016-06-06 20:14:05
Original
1290 people have browsed it

网站要做成一个中英文的,数据也要是中英文的,要怎么搞?

下面是我的一些想法:

建个模块,网站默认是中文,英文就放到英文的那个模块里,是英文的时候就调用英文的数据?
中文一套模板,英文一套模板?

<code> 'modules' => [
        'en' => ['class' => '\app\modules\english\Module'],
  ]</code>
Copy after login
Copy after login

那数据要怎么存呢?给每条数据都加一个字段,lang = 'en' / lang = 'zh' 这样?

还是个数据多加几个字段, 像下面这样,title 存中文, title_en 存英文?

<code>CREATE TABLE `courses` (
    `id` int(11) unsigned NOT NULL auto_increment,
    `title` varchar(255) NOT NULL default '',
    `title_en` varchar(255) NOT NULL default '',
    `cover` varchar(255) NOT NULL default '' comment '封面',
    `text` text,
    `text_en` text,
    `start_date` int(11) unsigned NOT NULL default 0 comment '开始日期',
    `end_date` int(11) unsigned NOT NULL default 0 comment '结束日期',
    `days` int(11) unsigned NOT NULL default 0 comment '有效天数',
    `maxnum` int(11) unsigned NOT NULL default 0 comment '最多报名人数',
    `has_num` int(11) unsigned NOT NULL default 0 comment '已报名人数',
    `price` decimal(10,2) comment '课程费',
    `created_at` int(11) unsigned default '0',
    `updated_at` int(11) unsigned default '0',
    `status` varchar(16) default 'on' comment 'on开启 off关闭 expire到期',
    `extra` text comment '额外的一些数据 可以使用序列化数据 serialize',
    PRIMARY KEY  (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8;</code>
Copy after login
Copy after login

求比较好的解决方法,像 苹果官网 的多语言是如何做的,数据是怎么存的?

回复内容:

网站要做成一个中英文的,数据也要是中英文的,要怎么搞?

下面是我的一些想法:

建个模块,网站默认是中文,英文就放到英文的那个模块里,是英文的时候就调用英文的数据?
中文一套模板,英文一套模板?

<code> 'modules' => [
        'en' => ['class' => '\app\modules\english\Module'],
  ]</code>
Copy after login
Copy after login

那数据要怎么存呢?给每条数据都加一个字段,lang = 'en' / lang = 'zh' 这样?

还是个数据多加几个字段, 像下面这样,title 存中文, title_en 存英文?

<code>CREATE TABLE `courses` (
    `id` int(11) unsigned NOT NULL auto_increment,
    `title` varchar(255) NOT NULL default '',
    `title_en` varchar(255) NOT NULL default '',
    `cover` varchar(255) NOT NULL default '' comment '封面',
    `text` text,
    `text_en` text,
    `start_date` int(11) unsigned NOT NULL default 0 comment '开始日期',
    `end_date` int(11) unsigned NOT NULL default 0 comment '结束日期',
    `days` int(11) unsigned NOT NULL default 0 comment '有效天数',
    `maxnum` int(11) unsigned NOT NULL default 0 comment '最多报名人数',
    `has_num` int(11) unsigned NOT NULL default 0 comment '已报名人数',
    `price` decimal(10,2) comment '课程费',
    `created_at` int(11) unsigned default '0',
    `updated_at` int(11) unsigned default '0',
    `status` varchar(16) default 'on' comment 'on开启 off关闭 expire到期',
    `extra` text comment '额外的一些数据 可以使用序列化数据 serialize',
    PRIMARY KEY  (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8;</code>
Copy after login
Copy after login

求比较好的解决方法,像 苹果官网 的多语言是如何做的,数据是怎么存的?

1、英语翻译成别的语言比较方便,Yii配置文件里可以配置sourceLanguage=>‘en-US',lanaguae=>'zh-CN',同时Yii::$app->language是一个可读可写的全局变量。

Yii::t() 方法的用法如下,

echo \Yii::t('app', 'This is a string to translate!');
第一个参数指储存消息来源的类别名称,第二个参数指需要被翻译的消息。

这个 Yii::t() 方法会调用 i18n 应用组件 来实现翻译工作。这个组件可以在应用程序中按下面的代码来配置,

'components' => [

<code>// ...
'i18n' => [
    'translations' => [
        'app*' => [
            'class' => 'yii\i18n\PhpMessageSource',
            //'basePath' => '@app/messages',
            //'sourceLanguage' => 'en-US',
            'fileMap' => [
                'app' => 'app.php',
                'app/error' => 'error.php',
            ],
        ],
    ],
], ], 在上面的代码中,配置了由 yii\i18n\PhpMessageSource 所支持的消息来源。模式 app* 表示所有以 app 开头的消息类别名称都使用这个翻译的消息来源。该 yii\i18n\PhpMessageSource 类使用 PHP</code>
Copy after login

文件来存储消息翻译。 每 PHP 文件对应单一类别的消息。默认情况下,文件名应该与类别名称相同。但是,你可以配置
yii\i18n\PhpMessageSource::fileMap 来映射一个类别到不同名称的 PHP 文件。在上面的例子中, 类别
app/error 被映射到PHP文件 @app/messages/ru-RU/error.php(假设 ru-RU
为目标语言)。如果没有此配置, 该类别将被映射到 @app/messages/ru-RU/app/error.php 。

除了在PHP文件中存储消息来源,也可以使用下面的消息来源在不同的存储来存储翻译的消息:

yii\i18n\GettextMessageSource 使用 GNU Gettext 的 MO 或 PO 文件保存翻译的消息。
yii\i18n\DbMessageSource 使用一个数据库表来存储翻译的消息。

补充一下Yii::t('app', 'This is a string to translate!',"zh-CN")这个方法可以传入目标语言参数。
2、数据库的内容,建议考虑多张表保存不同语言的那部分。如果每个语言一张表的话,扩展性较差;可以在表里加入language字段,根据Yii::$app->language和外键配置好关联也是很方便的。

数据库考虑可以创建结构完全一致的2个表:article_en、article_zn
使用同一个model,用url参数或者其他方法判断当前语言,在model中使用如下方法,切换对应的数据表:

<code>public static function tableName()
{
    if (//如果是中文) {
        $table_name = 'article_zn';
    } else {
        $table_name = 'article_en';
    }
    return $table_name;
}</code>
Copy after login

那要是支持10个国家的语言呢?都用数据库太浪费了。

可以借鉴tp框架的多语言,它是把不同的语言放入文件中。根据cookie或者session来区分语言,加载相应的语言文件。不过局限性也在于它好像只能做静态页面。

现在的骚年们使用框架前都不过一遍文档的吗?

Yii是支持多语言机制的。

赶紧戳这里看看吧。

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template