> 백엔드 개발 > PHP 튜토리얼 > Yii2中做中英文网站

Yii2中做中英文网站

WBOY
풀어 주다: 2016-06-06 20:14:05
원래의
1274명이 탐색했습니다.

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

下面是我的一些想法:

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

<code> 'modules' => [
        'en' => ['class' => '\app\modules\english\Module'],
  ]</code>
로그인 후 복사
로그인 후 복사

那数据要怎么存呢?给每条数据都加一个字段,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>
로그인 후 복사
로그인 후 복사

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

回复内容:

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

下面是我的一些想法:

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

<code> 'modules' => [
        'en' => ['class' => '\app\modules\english\Module'],
  ]</code>
로그인 후 복사
로그인 후 복사

那数据要怎么存呢?给每条数据都加一个字段,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>
로그인 후 복사
로그인 후 복사

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

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>
로그인 후 복사

文件来存储消息翻译。 每 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>
로그인 후 복사

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

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

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

Yii是支持多语言机制的。

赶紧戳这里看看吧。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿