Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/280.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/magento/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 在observer中获取篮子产品id_Php_Magento_Observers - Fatal编程技术网

Php 在observer中获取篮子产品id

Php 在observer中获取篮子产品id,php,magento,observers,Php,Magento,Observers,我为sales\u quote\u add\u item设置了一个观察者,以便在添加某个产品时清除购物车(它只应单独订购)。 我只是不确定如何获取即将添加的产品的产品ID。通过一些尝试和错误,我得出了以下结论: $tmp = $observer->getEvent()->getQuoteItem()->getData(); echo $tmp['product_id']; 这似乎是一个相当丑陋的解决方案。我确信有一些快捷方式或适当的函数可以调用,有什么想法吗?

我为
sales\u quote\u add\u item
设置了一个观察者,以便在添加某个产品时清除购物车(它只应单独订购)。 我只是不确定如何获取即将添加的产品的产品ID。通过一些尝试和错误,我得出了以下结论:

    $tmp = $observer->getEvent()->getQuoteItem()->getData();
    echo $tmp['product_id'];

这似乎是一个相当丑陋的解决方案。我确信有一些快捷方式或适当的函数可以调用,有什么想法吗?

使用以下代码获取报价项数据的产品id

$cart = Mage::getModel('checkout/cart')->getQuote();
foreach ($cart->getAllItems() as $item) 
{
   $productId = $item->getProduct()->getId();
}

希望这对您有所帮助。

您的解决方案已经足够好了

$productId = $observer->getEvent()->getQuoteItem()->getProductId();
如果需要,您可以在之后加载产品

$product = Mage::getModel('catalog/product')->load($productId);

这是所有购物车Id的,对吗?我正在尝试获取一个尚未添加的产品的ID,这个观察者会在它添加到购物车之前触发。呵呵,我想我已经尝试过了,但可能只有getId()。总之,它工作得很好,看起来比我那样访问阵列要好得多。谢谢