如何在比较页面Magento上显示相同的产品属性排序

时间:2014-08-21 05:35:52

标签: magento sorting attributes compare webpage

我不确定为什么比较页面上的产品属性排序与产品页面上的工作属性不同。就像在产品页面上一样,属性排序是

  产品页面

1 name 
2 new attribute 
3 new attribute1 
4 color

但是在comapre页面上,当我正在使用时,2个产品具有相同的属性,属性排序顺序变为

比较页面

1 name
2 color
3 new attribute
4 new attribute1 

我已经google了很多找到答案但无法找到答案。请帮我解决这个问题。

以下是我找到的功能

public function getComparableAttributes()
    {
        if (is_null($this->_comparableAttributes)) {
            $this->_comparableAttributes = array();
            $setIds = $this->_getAttributeSetIds();
            if ($setIds) {
                $attributeIds = $this->_getAttributeIdsBySetIds($setIds);

                $select = $this->getConnection()->select()
                    ->from(array('main_table' => $this->getTable('eav/attribute')))
                    ->join(
                        array('additional_table' => $this->getTable('catalog/eav_attribute')),
                        'additional_table.attribute_id=main_table.attribute_id'
                    )
                    ->joinLeft(
                        array('al' => $this->getTable('eav/attribute_label')),
                        'al.attribute_id = main_table.attribute_id AND al.store_id = ' . (int) $this->getStoreId(),
                        array('store_label' => $this->getConnection()->getCheckSql('al.value IS NULL', 'main_table.frontend_label', 'al.value'))
                    )
                    ->where('additional_table.is_comparable=?', 1)
                    ->where('main_table.attribute_id IN(?)', $attributeIds);
                $attributesData = $this->getConnection()->fetchAll($select);
                if ($attributesData) {
                    $entityType = Mage_Catalog_Model_Product::ENTITY;
                    Mage::getSingleton('eav/config')
                        ->importAttributesData($entityType, $attributesData);
                    foreach ($attributesData as $data) {
                        $attribute = Mage::getSingleton('eav/config')
                            ->getAttribute($entityType, $data['attribute_code']);
                        $this->_comparableAttributes[$attribute->getAttributeCode()] = $attribute;
                    }
                    unset($attributesData);
                }
            }
        }
        return $this->_comparableAttributes;
    }

/**
 * Load Comparable attributes
 *
 * @return Mage_Catalog_Model_Resource_Product_Compare_Item_Collection
 */
public function loadComparableAttributes()
{
    $comparableAttributes = $this->getComparableAttributes();
    $attributes = array();
    foreach ($comparableAttributes as $attribute) {
        $attributes[] = $attribute->getAttributeCode();
    }
    $this->addAttributeToSelect($attributes);

    return $this;
}

b我不明白如何按排序顺序过滤它。请建议

2 个答案:

答案 0 :(得分:0)

在产品页面属性上按属性集排序。

在比较页面属性上根本没有排序。 您可以在类 Mage_Catalog_Model_Resource_Product_Compare_Item_Collection 中重写函数 getComparableAttributes ,并实现您自己的排序逻辑。

但请注意,此功能在不同的Magento版本中有所不同。您可以尝试使用免费扩展程序ET Advanced Compare或从此扩展程序中获取部分代码(代码可在bitbucket.org上找到。链接i在扩展程序页面上)

答案 1 :(得分:0)

检查以下功能的修改: 使用的文件是 vendor / magento / module-catalog / Model / ResourceModel / Product / Compare / Item / Collection.php 但这不是最好的方法。你需要按照Magento标准覆盖它。 我正在努力,不久将更新。

public function getComparableAttributes()
{
    if ($this->_comparableAttributes === null) {
        $this->_comparableAttributes = [];
        $setIds = $this->_getAttributeSetIds();
        if ($setIds) {
            $attributeIds = $this->_getAttributeIdsBySetIds($setIds);

            $select = $this->getConnection()->select()->from(
                ['main_table' => $this->getTable('eav_attribute')]
            )->join(
                ['additional_table' => $this->getTable('catalog_eav_attribute')],
                'additional_table.attribute_id=main_table.attribute_id'
            )->joinLeft(
                ['al' => $this->getTable('eav_attribute_label')],
                'al.attribute_id = main_table.attribute_id AND al.store_id = ' . (int)$this->getStoreId(),
                [
                    'store_label' => $this->getConnection()->getCheckSql(
                        'al.value IS NULL',
                        'main_table.frontend_label',
                        'al.value'
                    )
                ]
            )
                    ->joinLeft( //add sort order to sort the attributes as per backend sort.  -- Abid
                ['as' => $this->getTable('eav_entity_attribute')],
                'as.attribute_id = main_table.attribute_id'
            )
                    ->where(
                'additional_table.is_comparable=?',
                1
            )->where(
                'main_table.attribute_id IN(?)',
                $attributeIds
            )
                    ->order('as.sort_order') //sort by sort_order -- Abid
                    ;
            $attributesData = $this->getConnection()->fetchAll($select);
            if ($attributesData) {
                $entityType = \Magento\Catalog\Model\Product::ENTITY;
                $this->_eavConfig->importAttributesData($entityType, $attributesData);
                foreach ($attributesData as $data) {
                    $attribute = $this->_eavConfig->getAttribute($entityType, $data['attribute_code']);
                    $this->_comparableAttributes[$attribute->getAttributeCode()] = $attribute;
                }
                unset($attributesData);
            }
        }
    }
    return $this->_comparableAttributes;
}