php - Magento:通过事件以编程方式更新购物车

标签 php zend-framework magento

我正在连接到 sales_quote_save_after 事件调度程序。首先,作为测试,我尝试获取购物车中的商品并将它们的价格更改为 0。在我这样做之后,我将构建一些其他内容。

我遇到了麻烦。我可以毫无问题地更改单价,但当我重新计算购物车总价时,价格又恢复为原始价格。

public function sales_quote_save_before($observer) {

    if (Mage::registry('basket_observer_executed')) {
        return $this;
    }

    $quote = $observer->getEvent()->getQuote();

    foreach ($quote->getAllItems() as $item) {
        if($item->getId()) {    
            $item->setCustomPrice(0);
        }
    }

    Mage::register('basket_observer_executed', true);

    $quote->save();
    $quote->setTotalsCollectedFlag(false)->collectTotals();
}

谁能指出我在重新计算总数的同时保持新价格?

最佳答案

我会尝试使用不同的事件。我总是使用 checkout_cart_save_after 来执行类似的操作。使用我提到的事件,使用以下代码:

$cart = $observer->getData('cart');

$quote = $cart->getData('quote');

$items = $quote->getAllVisibleItems();

foreach($items as $item)
{
    $item->setCustomPrice(0);
    $item->setOriginalCustomPrice(0);
    $item->getProduct()->setIsSuperMode(true);
    $item->save();
}
$quote->save();
$quote->setTotalsCollectedFlag(false)->collectTotals();

关于php - Magento:通过事件以编程方式更新购物车,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14362702/

相关文章:

php - XDebug 能否单独跟踪探查器调用所花费的时间?

database - 使用 Zend 和 doctrine 在数据库中查询现有用户名

mysql - Magento-Check.php 认为我使用的 MySQL 版本比我低

Magento 1.7 - 从/customer/account/create/中的注册中删除字段

php - 将 imagick 安装到 azure

php - 连接表后得到错误的值 - MySQL - PHP

javascript - .ajax jquery 方法的正确使用?

php - Youtube API PHP Zend GData 直接上传

php - Zend Framework 如何使用 partialLoop 列出表单元素

php - 管理页面上的 Magento 404