尝试在openart中添加特殊价格的jquery倒计时计时器


trying to add jquery countdown timer for special price in opencart

我正在尝试在openart中设置特殊价格的jquery倒计时计时器。

因为我们在open cart管理面板中有特价的开始日期和结束日期,

我想有一个jquery计数定时器显示剩余

(days:Hours:Min:SEC)

我得到jquery倒计时的代码,并把产品的模板文件,但它不工作,没有帮助或代码在互联网上。

谢谢

问得好。正如您所指出的,您希望显示的数据已经是OpenCart管理/后端的一部分,但它在前端不可用。我将向您展示如何添加它。

由于OpenCart的MVC架构,您将不得不在3个地方进行更改。模型,视图和控制器。首先,您必须从数据库中获取数据。因为我们希望对前端进行更改,所以所有内容都将包含在catalog目录中。如果您查看代码,您会发现catalog/model/catalog/product.php。这是我们要做第一个改变的地方。在ModelCatalogProduct中有特价,但是特价结束日期没有。您既可以修改现有的getProduct()方法,也可以创建自己的方法。我将向您展示后者,而前者留给用户作为练习。

目录/模型/目录/product.php

class ModelCatalogProduct extends Model {
    ...
    // Return an array containing special (price, date_start, date_end).
    // or false if no special price exists.
    public function getSpecialPriceDates($product_id) {
        if ($this->customer->isLogged()) {
            $customer_group_id = $this->customer->getCustomerGroupId();
        } else {
            $customer_group_id = $this->config->get('config_customer_group_id');
        }
        $query = $this->db->query("SELECT price, date_start, date_end FROM " . DB_PREFIX . "product_special WHERE product_id = '" . (int)$product_id . "' AND customer_group_id = '" . (int)$customer_group_id . "' AND ((date_start = '0000-00-00' OR date_start < NOW()) AND (date_end = '0000-00-00' OR date_end > NOW())) ORDER BY priority ASC, price ASC LIMIT 1");
        if ($query->num_rows) {
            return array(
                'special'    => $query->row['price'],
                'date_start' => $query->row['date_start'],
                'date_end'   => $query->row['date_end'],
            );
        } else {
            return false;
        }
    }
    ...
}

很好,现在有一个函数getSpecialPriceDates(),你可以调用它来找出一个产品特价何时结束。让我们将这些数据提供给视图。为了实现这个,我们需要把它添加到控制器。查看ControllerProductProduct中设置"special"变量的位置。

目录/控制器/产品/product.php

...
if ((float)$product_info['special']) {
    $this->data['special'] = $this->currency->format($this->tax->calculate($product_info['special'], $product_info['tax_class_id'], $this->config->get('config_tax')));
    // +++ NEW CODE
    $special_info = $this->model_catalog_product->getSpecialPriceDates($product_id);
    if ($special_info) {
        $this->data['special_date_end'] = $special_info['date_end'];
    } else {
        $this->date['special_date_end'] = false;
    }
    // +++ END NEW CODE
} else {
    $this->data['special'] = false;
}
...

最后一个任务是在产品视图中实现计时器。这将位于像catalog/view/theme/default/template/product/product这样的地方。Tpl (如果你有自己的主题,将default替换为{your-theme})。jQuery有很多不同的倒计时计时器解决方案,选择你最喜欢的。

目录/视图/主题/违约/模板/产品/product.tpl

    <?php if (!$special) { ?>
    <?php echo $price; ?>
    <?php } else { ?>
    <span class="price-old"><?php echo $price; ?></span> <span class="price-new"><?php echo $special; ?></span>
      <?php if ($special_date_end): ?>
      <!-- TIMER CODE HERE -->
      <div class="timer"></div>
      <?php endif; ?>
    <?php } ?>

看看我给你买了什么

也检查这个

这里有更多选项