如何显示产品的第二张图片? PrestaShop 1.7.5.1

时间:2019-05-23 07:27:27

标签: image prestashop prestashop-1.7

我只需要为一个特定的块显示ps_bestseller即可显示不同的封面图像(第二个或最后一个,并不重要,除第一个以外的所有图像)。

我唯一发现的是这段代码是link,但仅适用于1.6版本:

这是我的默认代码:

{block name='product_thumbnail'}

    {if $product.cover}

      <a href="{$product.url}" class="thumbnail product-thumbnail">
        <img
          src = "{$product.cover.bySize.home_default.url}"
          alt = "{if !empty($product.cover.legend)}{$product.cover.legend}{else}{$product.name|truncate:30:'...'}{/if}"
          data-full-size-image-url = "{$product.cover.large.url}"
        >
      </a>
    {else}
      <a href="{$product.url}" class="thumbnail product-thumbnail">
        <img
          src = "{$urls.no_picture_image.bySize.home_default.url}"
        >
      </a>
    {/if}
  {/block}

当我尝试编辑代码时,它将返回空白页。 有什么建议吗?

1 个答案:

答案 0 :(得分:1)

在以下内容中创建一个替换文件,该文件将在Link.php中命名为override/classes/

<?php
use PrestaShop\PrestaShop\Core\Addon\Module\ModuleManagerBuilder;
use PrestaShop\PrestaShop\Adapter\SymfonyContainer;
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
use PrestaShop\PrestaShop\Core\Feature\TokenInUrls;

class Link extends LinkCore
{
    public function getLastImageLink($id_product, $product_name, $type = null) {
        $maxId = Db::getInstance()->getValue('SELECT id_image FROM `'._DB_PREFIX_.'image` WHERE id_product = '.(int)$id_product.'  ORDER BY position DESC');
        return $this->getImageLink($product_name, $id_product.'-'.$maxId, $type = null);
    }
}

让dans le tpl倒入appeler l'url de votre图片mettez:

{$link->getLastImageLink($product.id, $product.name, 'large')}

致谢