我现在已经挣扎了一段时间了。一个我的CMS'随时可以使用翻译模块进行扩展。我一直在考虑不同的方法,但是到目前为止还没有找到最好的方法。
基本上我有一个CMS,它使用模板系统将数据库中的所有数据解析到屏幕上。我到目前为止已经分手了#34;我的模板在不同的文件夹中,以便能够翻译"静态"像带有文字,页脚链接等的图像
但是,有许多模块(页面,新闻,产品)具有多个字段,需要转换数据库驱动的方法。我开始使用"语言"描述语言的表(id,iso_code,name)。就我而言......由于有几个项目需要完成,到目前为止我还没有花费更多的时间来完成这个课程。
我的第一个想法("快速修复")是在表格中添加多个字段(例如" title_nl"," title_en"),但这实际上,数据库比我认为的更加拥挤。
我的第二个想法是创建一个表," news_translations"例如。其中包含语言iso代码,news_id,需要翻译的字段。显然,news_id将翻译连接到原始文件,语言iso代码用于从数据库中获取正确的语言。然后在我的前端代码中,我首先检查是否选择了默认语言(=>从" news"表中选择)或翻译(=>检查翻译表内)。如果第二种情况没有返回任何结果,则会显示一条消息"抱歉,没有可用的翻译和#34;并显示默认值(或错误消息,最适合客户的内容..)。
但是那里有第三个选项..我的网站都使用搜索引擎友好链接(www.domain.com/pagename/或www.domain.com/news/1-news-item-here.html) 。如果我有能力同时覆盖"那将会好得多。我的翻译表中的SEF URL。但我想在这种情况下,我总是需要1个额外的查询到翻译表(因为我们首先想要检查翻译的页面)...猜测它不是一个大问题,但它是#s值得考虑我猜。
最后我想通过描述我的选项3是我需要的。但是我也希望对这个问题有其他意见!这就是我想要实现的目标:
我认为选项3具有所有这些..所以创建此解决方案的步骤是:
为每个项目创建一个_translation表(或者甚至可以在 通过添加2个新字段' translation_to' (包含 PrimaryKey)和' translation_is' (包含ISO代码) - 但.. 在这种情况下,所有字段都需要进行编辑(并非总是如此) 必要..加上创建第二个表我保留原件 除了他们的翻译,对吧?)
如果未选择默认语言,首先查询翻译表以查找翻译,如果找到翻译,则显示翻译 翻译。否则通知/错误用户和/或显示 原始文本(基于SEF URL ...如果未找到SEF 在翻译或原始表中,然后显然显示 仅错误。)
有什么建议吗? : - )
感谢您的思考!
答案 0 :(得分:0)
从我从Drupal看到的情况来看,选项三是他们如何处理它,并进行了一些调整。他们将所有内容保存在一个表和一个称为语言的字段中。然后有一个单独的表来映射哪些项目已连接。
这种方式与主要语言无关,这意味着可以使用任何语言创建内容,而无需在任何其他语言中进行翻译。
答案 1 :(得分:0)
我想看看你的表结构是什么样的。你可以做的最好的事情就是生成两个单独的新表,名为“ CONTENT_MULTI_LANG ”& “的 SITE_LOCALES 强>”。
然后在打印出您的内容的代码中,初步检查语言标记。我将创建两个单独的类来加载静态内容,例如“ Content_LoadStandard ”和“ Content_LoadMultiLang ”。那么你的条件就像这样。
if ($this->site_locale == 'standard'){
$contentLoader = new Content_LoadStandard();
} else {
$contentLoader = new Content_LoadMultiLang($this->site_locale);
}
$content->blah($cheese);
您的“ CONTENT_MULTI_LANG ”表应该是标准CMS对象表的缩小版本,仅包含需要使用其他语言的相关内容字段。
// PSEUDO SQL
CREATE TABLE `LOCALE` (
`id` int(11),
`locale` varchar(16), // name of locale (language)
... // any other fields
)
CREATE TABLE `CONTENT_MULTI_LANG` (
`id` int(11),
`pcid` int(11), // parent content id
`lid` medint(), // locale id
`content` {$type}, // whatever type you use (varchar, text, bin, etc)
... // any other fields
)
在 Content_LoadMultiLang 类中,创建使用联接查询备用内容的方法。
提示:在您的表格中建立关系以在内容行上进行级联删除可能是个好主意,这样如果您删除标准内容,您的多语言版本也会被删除。