Magento获取指定分类下的产品和获取子分类及产品数量

Magento获取指定分类下的产品和获取子分类及产品数量


  1.       
  2. $customerId=客户Id;  
  3. $limit=10;  
  4. $orders=Mage::getResourceModel('sales/order_collection');  
  5. $orders->addAttributeToFilter('customer_id'$customerId)->getSelect()->order('e.entity_id desc')->limit($limit); 

Magento首页及分类页面侧边栏经常需要调用某一个分类下的产品,例如首页的Featured Product等。这些分类一般保持不激活状态,我们可以添加店铺中比较畅销的产品到该分类中,并从前台调用。下面一段代码主要用处就是在Magento中获取指定分类下的产品。

 
$products = Mage::getModel( 'catalog/category' )->load( $category_id )
     ->getProductCollection()
     ->addAttributeToSelect( '*' )
     ->addAttributeToFilter( 'status' , 1)
     ->addAttributeToFilter( 'visibility' , 4);

将上面的$category_id修改为需要显示产品的分类id,该id可以在分类页面中看到。上述代码中还捎带了一些过滤,产品状态为激活,并处于可见状态。

 

 

很多Magento的项目中,客户需求将每个当前分类下的每个子分类以及该分类下的产品数量全部显示出来,类似于Category (108)的形式。如下所示

Magento
- Magento 模板 (4)
- Magento 插件 (2)

想实现这种效果,就必须要知道如何获取当前分类的子分类,并了解Product Collection类中的count()方法。该方法用于获取任意形式下对于Product Collection进行筛选后的产品数量。

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
// 获取当前分类模型
$currCat = Mage::registry( 'current_category' );
 
//获取当前分类的所有子分类的模型集合
$collection = Mage::getModel( 'catalog/category' )->getCategories( $currCat ->getEntityId());
 
//循环子分类的模型集合
foreach ( $collection as $cat ) {
     if ( $cat ->getIsActive()) {
         $category = Mage::getModel( 'catalog/category' )->load( $cat ->getEntityId());
 
         //获取子分类的产品Collection,并通过count()方法,获取该子分类的产品数量
         $prodCollection = Mage::getResourceModel( 'catalog/product_collection' )->addCategoryFilter( $category );
         Mage::getSingleton( 'catalog/product_status' )->addVisibleFilterToCollection( $prodCollection );
         Mage::getSingleton( 'catalog/product_visibility' )->addVisibleInCatalogFilterToCollection( $prodCollection );
 
         $html .= '<a href="<?php echo $category->getUrl() ?>"><?php echo $category->getName() ?></a> (<?php echo $prodCollection->count() ?>)<br/>' ;
     }
}

 

分类: php
标签: Magento



如何获取magento 每个分类下前5个产品

$category_collection = Mage::getModel('catalog/category')->getCollection()
    ->setStoreId(1)
    ->addAttributeToSelect('name')
    ->addAttributeToSelect('url_path')
    ->addAttributeToSelect('is_active');

foreach($category_collection as $key=>$category) {
    $products= Mage::getModel('catalog/category')->load($category->getId())->getProductCollection()

    ->addAttributeToFilter('status', 1);
    ->addAttributeToFilter('visibility', 4); //catalog, search
    ->setOrder('entity_id', 'DESC')
    ->getSelect()->limit(5);

    foreach ($products as $key=>$product) {

        echo $product->getProductUrl();
    }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值