繁体   English   中英

Magento CMS阻止集合,无法按商店ID进行过滤-addStoreFilter([storeid])不起作用

[英]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/pagecms/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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM