magento获取当前站点的所有产品分类列表(急)

magento中怎么获取当前站点的所有产品分类列表并且按层次显示?类似于这样的... magento中怎么获取当前站点的所有产品分类列表并且按层次显示?
类似于这样的
展开
 我来答
cyan24
推荐于2016-05-09 · TA获得超过1626个赞
知道小有建树答主
回答量:1128
采纳率:0%
帮助的人:880万
展开全部
<?php
function nodeToArray(Varien_Data_Tree_Node $node) {
    $result = array();
    $result['category_id'] = $node->getId();
    $result['parent_id'] = $node->getParentId();
    $result['name'] = $node->getName();
    $result['is_active'] = $node->getIsActive();
    $result['position'] = $node->getPosition();
    $result['level'] = $node->getLevel();
    $result['children'] = array();
    foreach ($node->getChildren() as $child) {
        $result['children'][] = nodeToArray($child);
    }
    return $result;
}

function load_tree() {
    $tree = Mage::getResourceSingleton('catalog/category_tree')->load();
    $store = 1;
    $parentId = 1;
    $tree = Mage::getResourceSingleton('catalog/category_tree')->load();
    $root = $tree->getNodeById($parentId);
    if ($root && $root->getId() == 1) {
        $root->setName(Mage::helper('catalog')->__('Root'));
    }
    $collection = Mage::getModel('catalog/category')->getCollection()
                  ->setStoreId($store)
                  ->addAttributeToSelect('name')
                  //->addAttributeToSelect('id')
                  ->addAttributeToSelect('is_active');
    $tree->addCollectionData($collection, true);
    return nodeToArray($root);
}

function print_tree($tree, $level) {
    $level++;
    foreach ($tree as $item) {
        echo str_repeat("-", $level) . $item['name'] . '-' . $item['category_id'] . "<br>";
        print_tree($item['children'], $level);
    }
}

$tree = load_tree();
print_tree($tree['children'], 0);
?>

上面大抵是调用所有分类的,你可以参考下,直接拿去用估计需要小调整下,

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式