我想扩展 i18n 行为,以便它在任何类型的查询(DQL、关系、getTable)上自动加入转换表。
另外它需要定义默认语言参数,所以当我在没有设置语言的情况下进行查询时,它会回退到默认语言。
注意:我正在寻找通用行为,因此它适用于所有 i18n 模型对象,而不是为每个类编写和覆盖。
举个例子:
表 product
-> id, category_id, price...
表 product_translation
-> id, lang, name, description...
使用当前的解决方案,当我这样做时:Doctrine_Core::getTable('Product')->findAll()
,它在不加入翻译的情况下获取所有产品。
所以在 Controller 中,我必须遍历所有记录并重新应用翻译后的值,使用 $product->name = $product->Translation['en']->name
我想要这样的东西:
Doctrine_Core::getTable('Product')->findAll()
它应该获取 lang='en' 的连接值Doctrine_Core::getTable('Product)->findAll('en')
同上- 它也应该与关系一起工作,所以例如,如果我有一个类 User 有很多产品
$user->Products
它应该返回一个包含翻译的集合。 - 还有像
$user->Products('en')
应该返回其他(非默认)语言的集合 - 魔法函数也不错(如果可能的话)...像
Doctrine_Core::getTable('Product')->getByCategoryAndLang(1,'en')
有人可以帮忙吗?我正在查看模板和行为,我认为这是要走的路,但不知道如何实现这一点
编辑: 我发现大家对此兴趣不大,所以让我尝试一个更简单的问题。您通常如何通过关系获取 i18n 字段。例如,我如何调用 $user->Products
并获取带有加载翻译的产品?
最佳答案
我认为你不需要扩展标准的 Doctrine 行为,除非你想要它是全自动的。但是你仍然可以像我们一样尝试这样做——我们使用一个 DAO(数据访问对象)返回给我们具体的 Doctrine 实体(Doctrine 表表示):
\DAO::get('Some\Namespace\Classname')
哪里Classname
代表 PHP 类模型描述的表。我们的 DAO 类创建了 Classname
的实例封装到 proxy
中(请参阅设计模式)。
除了表类模型之外,我们为该表创建另一个类,它位于表模型之上并使用该模型进行操作。在这个类中,我们编写类似 getProducts($args)
的方法。 , getProduct($id)
, getProductsByCategory($catId)
等
我认为这就是您要找的...
在方法中getProducts($args)
然后你可以实现 ->leftJoin()
在 DQL 中,将通过给定 $lang
加入翻译表$args
中的标识符范围。简单示例(未测试):
class Products extends \DAO {
public function save($item) {
$item->save();
}
public function getProducts($args = array()) {
$order = array('p.id');
$result = \Doctrine_Query::create()
->from('Some\Namespace\Product p')
->where('1 = 1');
if(!empty($args['lang'])) {
$result = $result->leftJoin('Some\Namespace\ProductTranslation pt ON pt.product_id = p.id AND pt.language = ?', $args['lang']);
}
$result = $result->orderBy($order);
$result = $result->execute();
return $result;
}
}
然后调用
$products = DAO::get('Some\Namespace\Product')->getProducts(array('lang' => 1));
您获得所有加载了英文翻译的产品...
它不是那么自动化,你必须为每个模型编写你自己的 DAO 类,但这是一个很好的方法,因为你有 MVC/MVP 对象所需的不同数据定义类(模型)和数据操作类( Controller )面向应用架构...
关于php - Doctrine 1.2 自动加入 i18n?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5435834/