How to add Product Images To Your magento Navigation Menu? Recently, we had a request to add product images to the navigation menu for a client. We found a pretty neat solution which maintains itself well and can be seen in action here. This feature is asked by many magento users, so we decide to write a tutorial on this.
As standard, Magento comes with a navigation menu which pulls in all of your categories and subcategories. The issue with this is that changing it means editing the Magento core files fairly extensively which as you may or not have experienced, can often lead to issues when upgrading.
We initially started by pulling in the all the ‘active’ categories and subcategories inapp/design/frontend/yourtheme/yoursubtheme/template/catalog/category/list.phtml.
- <?php $_helper = Mage::helper(‘catalog/category’) ?>
- <?php $_categories = $_helper->getStoreCategories() ?>
- <?php $currentCategory = Mage::registry(‘current_category’) ?>
- <?php if (count($_categories) > 0): ?>
- <ul id=“nav”>
- <?php foreach($_categories as $_category): ?>
- <li>
- <a href=”<?php echo $_helper->getCategoryUrl($_category) ?>“>
- <span>
- <?php echo $_category->getName() ?>
- </span>
- </a>
- <?php $_category = Mage::getModel(‘catalog/category’)->load($_category->getId()) ?>
- <?php $_subcategories = $_category->getChildrenCategories() ?>
- <?php if (count($_subcategories) > 0): ?>
- <ul class=“sub”>
- <?php foreach($_subcategories as $_subcategory):
- $products = Mage::getResourceModel(‘catalog/product_collection’)->addCategoryFilter($_subcategory)->addAttributeToSelect(‘small_image’);
- $products->getSelect()->order(new Zend_Db_Expr(‘RAND()’))->limit(1);
- $products->load();?>
- <li>
- <a href=”<?php echo $_helper->getCategoryUrl($_subcategory) ?>“>
- <span>
- <?php echo $_subcategory->getName() ?>
- </span>
- <?php foreach($products as $product) { ?>
- <img src=”<?php echo $this->helper(‘catalog/image’)->init($product, ‘small_image’)->resize(150, 150); ?>“ width=”150″ height=”150″ alt=”<?php echo $_subcategory->getName() ?>“ />
- <?php break; } ?>
- </a>
- </li>
- <?php endforeach; ?>
- </ul>
- <?php endif; ?>
- </li>
- <?php endforeach; ?>
- </ul>
- <?php endif; ?>
So at this point, we have all the categories and subcategories of magento with images on the sub-cats. The script takes a random image from each category and then takes that products image. How about a bit of style then? Ok, so we only want to see the image of the sub-category that we’re hovering over right? This style snippet should soon sort that out:
- #nav ul li a img { display:none; position:absolute; right:30px; top:0px; }
- var $j = jQuery.noConflict();
- $j(document).ready(function(){
- $j(‘#nav .sub li’).each(function() {
- $j(‘a’, this).hover(function() {
- $j(‘img’, this).fadeIn();
- }, function() {
- $j(‘img’, this).fadeOut();
- });
- });
- });
Done! You should have a fully working navigation menu with product images.
You may also try this Magento Mega Menu extension to generate a professional looking Magento Navigation Menu
Không có nhận xét nào:
Đăng nhận xét