Magento在产品页面提供了一个简单的图片放大功能,不是非常好,假设考虑使用放大镜来使用户查看产品的大图。能够考虑使用基于jQuery的插件,jqZoom便是一款优秀的放大镜插件。以下将介绍如何把jqzoom集成到Magento中。

1 载入jQuery
由于jqZoom是基于jQuery的插件,所以我们须要在Magento中载入jQuery库,并下载jqZoom文件包,放在站点的根文件夹的js文件夹下,比方/js/jqzoom

2 建立模块
作为样例,我们在/app/code/local/MagentoBoy/Jqzoom文件夹下新建一个模块MagentoBoy_Jqzoom。并加入模块文件:
/app/etc/modules/MagentoBoy_Jqzoom.xml
  1. <?

    xml version="1.0"?>

  2. <config>
  3. <modules>
  4. <MagentoBoy_Jqzoom>
  5. <active>true</active>
  6. <codePool>local</codePool>
  7. </MagentoBoy_Jqzoom>
  8. </modules>
  9. </config>
并加入配置文件
/app/code/local/MagentoBoy/Jqzoom/etc/config.xml
  1. <?xml version="1.0"?>
  2. <config>
  3. <modules>
  4. <MagentoBoy_Jqzoom>
  5. <version>0.1.0</version>
  6. </MagentoBoy_Jqzoom>
  7. </modules>
  8. </config>

3 加入Layout文件
/app/design/frontend/default/default/layout/jqzoom.xml
  1. <?xml version="1.0"?>
  2. <layout>
  3. <catalog_product_view>
  4. <reference name="head">
  5. <action method="addItem"><type>js</type><name>jqzoom/js/jquery.jqzoom-core.js</name></action>
  6. <action method="addItem"><type>js_css</type><name>jqzoom/css/jquery.jqzoom.css</name></action>
  7. </reference>
  8. <reference name="product.info.media">
  9. <action method="setTemplate"><template>jqzoom/media.phtml</template></action>
  10. </reference>
  11. </catalog_product_view>
  12. <review_product_list>
  13. <reference name="head">
  14. <action method="addItem"><type>js</type><name>jqzoom/js/jquery.jqzoom-core.js</name></action>
  15. <action method="addItem"><type>js_css</type><name>jqzoom/css/jquery.jqzoom.css</name></action>
  16. </reference>
  17. <reference name="product.info.media">
  18. <action method="setTemplate"><template>jqzoom/media.phtml</template></action>
  19. <action method="disableGallery"/>
  20. </reference>
  21. </review_product_list>
  22. </layout>
并在config.xml中加入layout文件
  1. <config>
  2. <frontend>
  3. <layout>
  4. <updates>
  5. <jqzoom>
  6. <file>jqzoom.xml</file>
  7. </jqzoom>
  8. </updates>
  9. </layout>
  10. </frontend>
  11. </config>

4 改动template文件
/app/design/frontend/default/default/template/jqzoom/media.phtml
  1. <?

    php

  2. $_product = $this->getProduct();
  3. $_helper = $this->helper('catalog/output');
  4. ?>
  5. <?php if ($_product->getImage() != 'no_selection' && $_product->getImage()): ?>
  6. <p class="product-image">
  7. <a href="<?php
    echo $this->helper('catalog/image')->init($_product, 'image');?

    >" class="jqzoom" rel="gal1" title="<?php
    echo $this->htmlEscape($this->getImageLabel());?>">

  8. <img id="image" src="<?

    php
    echo Mage::helper('catalog/image')->init($_product, 'thumbnail')->resize(265);?>" alt="<?

    php
    echo $this->htmlEscape($this->getImageLabel());?

    >" title="<?php echo
    $this->htmlEscape($this->getImageLabel());?>" style="width:265px;" />

  9. </a>
  10. </p>
  11. <p class="zoom-notice" id="track_hint"><?php echo $this->__('Hover
    on image to zoom in the picture') ?></p>
  12. <?php else: ?>
  13. <p class="product-image">
  14. <?php
  15. $_img = '<img
    src="'.$this->helper('catalog/image')->init($_product, 'image')->resize(265).'"
    alt="'.$this->htmlEscape($this->getImageLabel()).'"
    title="'.$this->htmlEscape($this->getImageLabel()).'"
    />';
  16. echo $_helper->productAttribute($_product, $_img, 'image');
  17. ?

    >

  18. </p>
  19. <?

    php endif; ?>

  20. <?

    php if (count($this->getGalleryImages()) > 0): ?

    >

  21. <div class="more-views">
  22. <h2><?php echo $this->__('More
    Views') ?

    ></h2>

  23. <ul>
  24. <li>
  25. <a class="zoomThumbActive" href="javascript:void(0);" rel="{gallery:'gal1',
    smallimage:'<?php echo Mage::helper('catalog/image')->init($_product, 'thumbnail')->resize(265);?>', largeimage:'<?php echo $this->helper('catalog/image')->init($_product, 'image');?>'}" title="<?php
    echo $this->htmlEscape($this->getImageLabel());?>"><img src="<?php
    echo Mage::helper('catalog/image')->init($_product, 'thumbnail')->resize(56);?>" width="56" height="56" alt="<?php
    echo $this->htmlEscape($this->getImageLabel());?>" /></a>
  26. </li>
  27. <?php foreach ($this->getGalleryImages() as $_image): ?

    >

  28. <li>
  29. <a href="javascript:void(0);" rel="{gallery:'gal1',
    smallimage:'<?php echo Mage::helper('catalog/image')->init($_product, 'thumbnail', $_image->getFile())->resize(265);?>', largeimage:'<?php echo $this->helper('catalog/image')->init($_product, 'image', $_image->getFile());?

    >'}" title="<?php
    echo $this->htmlEscape($this->getImageLabel());?>"><img src="<?php
    echo Mage::helper('catalog/image')->init($_product, 'thumbnail', $_image->getFile())->resize(56);?>" width="56" height="56" alt="<?php
    echo $this->htmlEscape($this->getImageLabel());?>" /></a>

  30. </li>
  31. <?php endforeach; ?

    >

  32. </ul>
  33. </div>
  34. <?

    php endif; ?

    >

  35. <script type="text/javascript">
  36. //<![CDATA[
  37. var $j = jQuery.noConflict();
  38. $j(document).ready(function(){
  39. $j('.jqzoom').jqzoom({
  40. 'zoomWidth' : 300,
  41. 'zoomHeight' : 300,
  42. 'xOffset' : 10,
  43. 'yOffset' : 0,
  44. 'position' : 'right',
  45. 'preloadImages' : true,
  46. 'preloadText' : 'Loading zoom',
  47. 'title' : true,
  48. 'lens' : true,
  49. 'imageOpacity' : '0.4',
  50. 'showEffect' : 'show',
  51. 'hideEffect' : 'hide',
  52. 'fadeinSpeed' : 'slow',
  53. 'fadeoutSpeed' : '2000'
  54. });
  55. });
  56. //]]>
  57. </script>

清除缓存。刷新头版。当鼠标悬停在产品形象,看产品的放大图。

版权声明:本文博客原创文章。博客,未经同意,不得转载。

在Magento产品页面的使用jqZoom的更多相关文章

  1. Magento给新产品页面添加分页

    本文介绍如何让magento创建一个带分页功能的新到产品页面,方便我们在首页或者其它CMS Page调用和展示新到产品. 在Magento我们经常有的做法是建立一个可以调用新产品的block,然后通过 ...

  2. 如何给magento的产品页面添加返回按钮

    如何给magento的产品页面添加返回按钮,最模板提供教程 第一步: 打开 E:\xampp\htdocs\magento\skin\frontend\default\bluescale\css\st ...

  3. 如何修改magento产品详细页面的栏目

    magento默认模板里面的产品信息页面的布局是以两栏带右侧栏显示的,那么如何修改为两栏带左侧栏或者三栏.一栏的方式显示呢?下面教大家一种很简单的方法就可以实现.下面是默认的布局预览:

  4. 如何实现Magento产品批量导入?

    从事外贸的我们在工作中,经常需要添加成千上万个的产品,如果一个一个的去上传,要花费很多时间,有是很让人头痛,那么应该如何实现产品批量上传?如果使用的是Magento系统的话,那么你现在有福利了,因为M ...

  5. Magento产品批量导入方法?

    从事外贸的我们在工作中,经常需要添加成千上万个的产品,如果一个一个的去上传,要花费很多时间,有是很让人头痛,那么应该如何实现产品批量上传?如果使用的是Magento系统的话,那么你现在有福利了,因为M ...

  6. magento产品批量导出导入

    magento产品批量导出导入 博客分类: WP / Joomla! / Magento / Shopify / Drupal / Moodle / Zimbra ExcelMobile配置管理XML ...

  7. magento产品成功添加到购物车后跳转到不同页面 添加 add to cart 按钮

    1 添加产品到购物车成功后是跳转到购物车页面或不跳转.这个在后台可以设置 system -> configuration -> After Adding a Product Redirec ...

  8. 如何修改magento分类页面的产品的显示个数

    经常的有客户问,怎么修改分类页面的产品的个数 这个是magneto后台操作的设置问题 打开后台,在英文状态下: system-->configuration 进入后,点击catalog Prod ...

  9. magento 获得当前产品页面的产品id

    $product_id = Mage::registry('current_product')->getId();

随机推荐

  1. HTC M7日文版HTL22刷机包 毒蛇2.5.0 ART NFC Sense6.0

    ROM介绍 日文版的蝰蛇2.5.0简短的介绍: *根据最新的M8蝰蛇版本号2.5.0 *经过我的朋友和机器测试.功能是否正常,当然,并非所有的功能进行测试,以,假设遇到BUG请反馈 *删除国外社会.谷 ...

  2. ajaxFileUpload+struts2多文件上传(动态添加文件上传框)

    上一篇文章http://blog.csdn.net/itmyhome1990/article/details/36396291介绍了ajaxfileupload实现多文件上传, 但仅仅是固定的文件个数 ...

  3. nginx随着passenger构造ruby on rails页

    1.备份nginx简介 cp /opt/nginx/html/nginx.conf /opt/nginx/html/nginx.conf.bak 2.编者nginx简介 server { listen ...

  4. 默认情况下安装的应用程序C盘后提示权限不足,当你开始介意。。。

    最近,不少用户抱怨的经销商.正在使用win 7我们的计算机系统上安装软件后,提示权限不够开放系统,无法启动软件. 在xp该系统是没有问题的.原因是,我们会选择在默认安装路径系统C-disk.和win ...

  5. 【Stackoverflow好问题】祛烦“!=null&quot;()判处空语句

    问题 为了避免空指针调用,我们常常会看到这种语句 ...if (someobject != null) { someobject.doCalc();}... 终于.项目中会存在大量判空代码.多么丑陋繁 ...

  6. 为RadComboBox添加SelectionChanging事件

    代码非标准,仅供参考. using System; using System.Collections.Generic; using System.Linq; using System.Windows. ...

  7. 第十二章——SQLServer统计信息(3)——发现过期统计信息并处理

    原文:第十二章--SQLServer统计信息(3)--发现过期统计信息并处理 前言: 统计信息是关于谓词中的数据分布的主要信息源,如果不知道具体的数据分布,优化器不能获得预估的数据集,从而不能统计需要 ...

  8. JAVA学习课第五十八届 — GUI

    GUI Graghical User Interface(图形用户接口) java为GUI提供的对象都存在java.awt和java.swing包中 Java的GUI做的的确干只是C++等.不打算浪费 ...

  9. What is Observer and Observable and when we used these?

    转会:http://stackoverflow.com/questions/13744450/interview-when-do-we-use-observer-and-observable

  10. 大虾翻译(一):jQuery.extend()

    本文是在JavaScript之三里面链接内容的中文翻译.我会尽可能做到信达雅且保持作者原意不变,OK,let's Go! jQuery.extend(target,[object1],[objectN ...