[英]Magento CMS Block Collection, can't filter by store id - addStoreFilter([storeid]) not working
如何过滤cms / block(静态块)集合?
这适用于cms页面:
$model = Mage::getModel('cms/page');
$collection = $model->getCollection()->addStoreFilter(3);
这不起作用(返回未过滤的集合):
$model = Mage::getModel('cms/block');
$collection = $model->getCollection()->addStoreFilter(3);
我还尝试使用资源模型“ cms / block”和“ cms / block_collection”,但没有结果。
为什么Magento如此罕见?! 有时候我真的开始为此讨厌Magento。 请帮忙。
您未过滤的确切含义是什么?
addStoreFilter具有第二个参数,还包括管理存储
addStoreFilter($store, $withAdmin = true)
因此,如果您有任何链接到所有商店的静态块,这些也将在您的收藏夹中。
这是您的问题吗?
试试这个代码:
$collection = Mage::getModel('cms/block')->getCollection();
$select = $collection->getSelect()->join(
array('block_store' => $collection->getTable('cms/block_store')),
'main_table.block_id = block_store.block_id',
array('store_id')
)->where('block_store.store_id IN (?)', array(8));
foreach ($collection as $block) {
// here you can use $block
}
您可以对cms/page
执行相同的操作。 只是改变
cms/block
cms/page_store
> cms/page
和cms/block_store
> cms/page_store
好的,首先要感谢Mike和oleksii.scarychevskyi。 这两个答案都帮助我使其正常运行。 使用此方法效果很好,我更喜欢以下方法:
$collection = Mage::getModel('cms/block')->getCollection()->addStoreFilter(3, false);
oleksiis解决方案也有效,我不知道我们可以用这种方式更改选择。
这对我来说可以通过标识符获取静态块:
$storeId = 2;
$content = Mage::getModel('cms/block')->setStoreId($storeId)->load('aboutus')->getContent();
echo $content;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.