4

我目前正在为我的第一个 magento 构建中显示的产品选项获取图像。我已经为捆绑产品找到了这个,如下所示:

截屏

当构建选择的选项时,我正在获取相关图像(例如样本)的 url。现在我正在尝试对可配置产品做同样的事情,但它似乎并不那么简单。

可配置产品由代表可用选项的每次迭代的简单产品构建而成。伟大的。我显然可以为每个简单的产品上传图片,这将是解决此问题的良好开端。

例如:椅子有 3 种内饰和 2 种扶手选择(6 种简单产品)。对于椅子 2/b,我上传了内饰样本 2 和扶手样本 b,并相应地标记它们。构建选项后,我会通过标签获取与每个简单产品相关联的图像 url(可能会获取该标签的所有图像并删除重复项或其他内容?)...

在 Magento 中,我看到:

主题/目录/产品/视图/类型/选项/configurable.phtml

<?php foreach($_attributes as $_attribute): ?>
    ..// 
    <select name="super_attribute[<?php echo $_attribute->getAttributeId() ?>]" id="attribute<?php echo $_attribute->getAttributeId() ?>" class="required-entry super-attribute-select">
        <option><?php echo $this->__('Choose an Option...') ?></option>
    </select>
    ..//
</div>
<?php endforeach; ?>
<script type="text/javascript">
    var spConfig = new Product.Config(<?php echo $this->getJsonConfig() ?>);
</script>

js/varien/configurable.js与捆绑包不同,可配置的产品选择/选项通过 javascript (in )注入页面。然后依赖这个类getJsonConfig()来提供之后的所有信息。

此时,似乎我应该能够从该对象获取一个简单的产品图片 url 信息。尽管我在configurable.js 中根本看不到处理图像的逻辑。 我将如何获取这些 url 并将它们与相关选项相关联?

任何关于我应该如何进行的建议都会很棒。

干杯


......还有:这看起来真的是绝对必要的功能。为什么 magento 不支持开箱即用的东西?


更新

对于那些对类似事物感兴趣的人,我终于弄清楚了。

我处理此问题的第一种方法 - 从子产品中获取图像在一定程度上起作用,但在尝试获取多组属性的唯一图像 url 时变得令人费解。这也意味着必须为简单产品中的每个选项提供图像,因此 - 大量不必要的劳动力。

我最终使用了@Greg Demetrick 建议的免费插件(进行了一些修改)。它是一个非常可靠的小模块,它允许将图像 url 与任何属性选项 / 以及一些获取它们的方法相关联。

我的最终解决方案看起来有点像这样:

目录/产品/视图/类型/选项/configurable.phtml

<?php foreach($_attributes as $_attribute): ?>

  // markup for the attribute

    <script type="text/javascript">
        //<![CDATA[
        var attribute_data_<?php echo $_attribute->getAttributeId() ?> = {};
            attribute_data_<?php echo $_attribute->getAttributeId() ?>.id = '<?php echo $_attribute->getAttributeId() ?>';
            attribute_data_<?php echo $_attribute->getAttributeId() ?>.title = '<?php echo $_attribute->getLabel() ?>';
            attribute_data_<?php echo $_attribute->getAttributeId() ?>.data = {};
        <?php 
        $a = Mage::getModel('eav/config')->getAttribute('catalog_product', $_attribute->getAttributeId() );
        $helper = Mage::helper('attributeoptionimage');
        foreach ( $a->getSource()->getAllOptions(true) as $option): ?>
            attribute_data_<?php echo $_attribute->getAttributeId() ?>.data.option_<?php echo $option['value'] ?> = {};
            attribute_data_<?php echo $_attribute->getAttributeId() ?>.data.option_<?php echo $option['value'] ?>.val = '<?php echo $option['value'] ?>';
            attribute_data_<?php echo $_attribute->getAttributeId() ?>.data.option_<?php echo $option['value'] ?>.imageurl = '<?php echo $helper->getAttributeOptionImage($option['value']); ?>';
            attribute_data_<?php echo $_attribute->getAttributeId() ?>.data.option_<?php echo $option['value'] ?>.imgtitle = '<?php echo $option['label']; ?>';
        <?php endforeach; ?>
        //]]>
    </script>

    <?php endforeach; ?>

这将打印在标记中,每个属性一组。效果很好,但返回属性的所有选项,而不仅仅是为产品选择的选项(getJsonConfig()对象已存储的数据)。所以,然后我只是attribute_data_xxx针对 测试我的对象spConfig,并将唯一的匹配选项发送到我的控制器脚本。

扩展getJsonConfig以获取属性 url 可能也可以工作......

无论如何 - 这里的关键点是将图像 url 与属性选项本身(而不是产品)相关联。

干杯

4

2 回答 2

6

getUsedProducts()使用方法可以得到可配置中使用的简单产品数组。此方法不是标准产品模型的一部分,但可以在 中找到app/code/core/Mage/Catalog/Model/Product/Type/Configurable.php,因此您需要首先使用 获取可配置产品模型getTypeInstance()。该方法接受一个参数,说明您是否希望将类型模型作为单例返回(我做过)。

foreach ($_product->getTypeInstance(true)->getUsedProducts() as $simpleProduct) {
    // From this you should be able to get the image url
}

更新

spConfig由创建的数组中,Mage_Catalog_Block_Product_View_Type_Configurable::getJsonConfig()有一个options包含特定于该可配置选项的 product_ids 的数组。

spConfig :
  attributes : {
    603 : {
      id      : 603,
      code    : part_state,
      label   : "Part State",
      options : [
        {
          id       : 648,
          label    : Harvested,
          price    : 0,
          products : [204379]   // <-- Simple Product ID
        },
        {
          id       : 647,
          label    : New,
          price    : 0,
          products : [224333]
        }]
    },
  ...

此时,您可以:

  1. 扩展getJsonConfig为包含一个简单的产品图片 URL,或者
  2. 创建简单产品 ID 到图像 URL 的映射

我会给你一个#2的例子,这样你就可以看到你可能会使用什么功能。

$spImages = array();
foreach ($this->getAllowProducts() as $_sp) {
    $spImages[$_sp->getId()] = 
        (string)$this->helper('catalog/image')
            ->init($_sp, 'small_image')
            ->resize(40,40);
}
// It is necessary to cast the URL to a `string` because the actual work done by
// Mage_Catalog_Helper_Image happens in the `__toString()` method... weird!

<script type="text/javascript">
    var spImages = <?php echo json_encode($spImages); ?>;
</script>

现在您可以将图像 URL 与简单的产品 ID 关联起来,您需要根据当前选择的选项更新图像。MagentoProduct.Config有一个configureElement()在更改时触发的方法<select class="super-attribute-select">,所以我会利用它。如果您不喜欢这样做,那么您已经获得了spConfig.config可以spImages编写自己的onChange事件处理程序的所有信息。

于 2012-07-24T16:38:44.910 回答
3

我认为您将在这里遇到的最终问题是属性中的选项没有与之关联的图像。您可能需要安装诸如 GoMage 的高级导航之类的东西,它将为您添加该功能。在基本 Magento 中,图像仅与产品相关联,这就是为什么您可以将它们提取为捆绑产品的原因。

一旦有了图像选项,您应该能够从 Magento 中添加的表格中按产品提取选项图像,在加载时显示每个选项的基本图像,然后在选择时为其他图像放入 JS 交换. 我的建议是下载下面的免费“带有选项的图像”模块并安装它。这将添加一个新的帮助类来显示图像,并且可能还会为您提供交换所需的代码。

GoMage 模块:http ://www.gomage.com/extensions/searching-optimization/gomage-advanced-navigation.html/

类似功能的免费版本:http: //www.johannreinke.com/en/2012/02/05/magento-add-images-to-product-attribute-options/

于 2012-07-23T18:05:41.087 回答