欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jquery圖片放大鏡功能的實例代碼

 更新時間:2013年03月26日 09:16:13   作者:  
jquery圖片放大鏡功能的實例代碼,需要的朋友可以參考一下

復(fù)制代碼 代碼如下:

/*放大鏡*/
.ZoomMain {margin:100px;width:395px;height:460px;float:left;position:relative;}
.ZoomMain .zoom {height:393px;width:393px;position:relative;border: 1px solid #dcdddd;}
.ZoomMain .zoom .move{position:absolute;left:0; top:0;display:none;width:195px; height:195px;background:#000;opacity:0.2;filter:Alpha(Opacity=20);}
.ZoomMain .zoomDetail{display:none;border:1px solid #DCDDDD;width:393px; height:393px; position:absolute;right:-405px;top:0px; overflow:hidden;}
.littleImg {margin-top:10px;height:54px;overflow:hidden;position:relative;}
.littleImg span {position: absolute;display:block;width:10px;height:55px;background:#999;cursor:pointer;}
.littleImg span em {display: none;width:10px;height:55px;}
.littleImg span.btnL {left:0;background: url(oohdear/images/cssPos/UltimatePageCssPos.gif) no-repeat left top;}
.littleImg span.btnL em {background: url(oohdear/images/cssPos/UltimatePageCssPos.gif) no-repeat left -57px;}
.littleImg span.btnR em {background: url(oohdear/images/cssPos/UltimatePageCssPos.gif) no-repeat -10px -57px;}
.littleImg span.btnR {right:0;background: url(oohdear/images/cssPos/UltimatePageCssPos.gif) no-repeat -10px top;}
.littleImg span.hover em {display:block;}
.littleImg .slideMain {width:343px;height:55px;margin-left:26px;overflow:hidden;position:relative;}
.littleImg .slideMain ul {position:absolute;left:0;width:355px;padding-top:1px;}
.littleImg .slideMain ul li {float:left;margin-right:6px;cursor:pointer;width:50px;height:50px;border:1px solid #dbdbdb;}
.littleImg .slideMain ul li.selected {border-color:#999;}
.littleImg .slideMain ul li img {float:left;width:50px;height:50px;}
/*放大鏡end*/
</style>
</head>
<body>
<!--放大鏡-->
<div class="ZoomMain">
  <div class="zoom">
         <span class="move"></span>
         <img width="393" height="390"  src="1347000569971.jpg" />
  </div>
  <div class="littleImg">
       <span class="btnL"><em></em></span>
       <span class="btnR"><em></em></span>
        <div class="slideMain">
              <ul class="clearfix">
                <li class="selected"><img width="50" height="50" src="1347000569971.jpg" medium-img="1347000569971.jpg" large-img="1347000569971.jpg" /></li>
                <li><img width="50" height="50" src="1347000590691.jpg" medium-img="1347000590691.jpg" large-img="1347000590691.jpg" /></li>
                <li><img width="50" height="50" src="1347000569971.jpg" medium-img="1347000569971.jpg" large-img="1347000569971.jpg" /></li>
                <li><img width="50" height="50" src="1347000590691.jpg" medium-img="1347000590691.jpg" large-img="1347000590691.jpg" /></li>
                <li><img width="50" height="50" src="1347000569971.jpg" medium-img="1347000569971.jpg" large-img="1347000569971.jpg" /></li>
                <li><img width="50" height="50" src="1347000590691.jpg" medium-img="1347000590691.jpg" large-img="1347000590691.jpg" /></li>
                <li><img width="50" height="50" src="1347000569971.jpg" medium-img="1347000569971.jpg" large-img="1347000569971.jpg" /></li>
                <li><img width="50" height="50" src="1347000590691.jpg" medium-img="1347000590691.jpg" large-img="1347000590691.jpg" /></li>
                <li><img width="50" height="50" src="1347000569971.jpg" medium-img="1347000569971.jpg" large-img="1347000569971.jpg" /></li>
                <li><img width="50" height="50" src="1347000590691.jpg" medium-img="1347000590691.jpg" large-img="1347000590691.jpg" /></li>
                <li><img width="50" height="50" src="1347000569971.jpg" medium-img="1347000569971.jpg" large-img="1347000569971.jpg" /></li>
                <li><img width="50" height="50" src="1347000590691.jpg" medium-img="1347000590691.jpg" large-img="1347000590691.jpg" /></li>
                <li><img width="50" height="50" src="1347000569971.jpg" medium-img="1347000569971.jpg" large-img="1347000569971.jpg" /></li>
                <li><img width="50" height="50" src="1347000590691.jpg" medium-img="1347000590691.jpg" large-img="1347000590691.jpg" /></li>
              </ul>
        </div>
  </div>
  <div class="zoomDetail">
            <img width="701" height="701" src="1347000569971.jpg" />
  </div>
</div>
<!--放大鏡end-->
  

?<script type="text/javascript">
/**
@開發(fā):楊永
@功能:實現(xiàn)細(xì)節(jié)放大,圖片對應(yīng)切換,自由定義css樣式實現(xiàn)自由鋪滿視口等功能
@說明:基于jQ的放大鏡插件,可根據(jù)需要自由調(diào)整布局來適應(yīng)各種設(shè)計效果
*/
(function(){
        function Zoom(object){
                this.zoomArea=$(".zoom",object);//保存促發(fā)放大效果的區(qū)域
                this.moveArea=$(".move",object);//保存移動區(qū)域
                this.zoomDetail=$(".zoomDetail",object);//保存放大鏡區(qū)域
                this.zoomDetailImg=$("img",this.zoomDetail);//保存放大鏡里面的圖
                this.zoomAreaWidth=this.zoomArea.width();
                this.moveAreaWidth=this.moveArea.width();
                this.zoomAreaHeight=this.zoomArea.height();
                this.moveAreaHeight=this.moveArea.height();
                this.zoomDetailWidth=this.zoomDetail.width();
                this.zoomDetailHeight=this.zoomDetail.height();
                this.zoomAreaOffset=this.zoomArea.offset();//初始化放大區(qū)域在視口中的相對偏移;
                this.XY=null;//初始化鼠標(biāo)相對于放大區(qū)域的偏移偏移值
                this.moveBili=null;//
                var _this_=this;
                this.zoomArea.mousemove(function(e){//當(dāng)鼠標(biāo)在放大區(qū)域移動的時候執(zhí)行
                                                 _this_.move(e.pageX,e.pageY);   
                                        }).mouseover(function(){
                                            _this_.moveArea.show();
                                            _this_.zoomDetail.show();
                                            }).mouseout(function(){
                                                _this_.moveArea.hide();
                                                _this_.zoomDetail.hide();                                               
                                                });
                this.calculate();//初始化并計算出需要的比例值
                //以下是小圖部分的功能實現(xiàn)
                this.l=0;
                this.scrollObj=$(".slideMain ul",object);//保存ul滾動對象
                this.lis=this.scrollObj.children();//保存小圖片列表
                this.btnR=$(".btnR",object);//保存右邊按鈕
                this.btnL=$(".btnL",object);//保存左邊邊按鈕
                this.lis.click(function(){
                                        _this_.changeImgSrc(this);
                                        });
                if(this.lis.length>6){//判斷圖片數(shù)是否超出顯示區(qū)域,是的話就注冊滾動事件
                    this.s=this.lis.length-6;//獲取多余出來的圖片數(shù)
                    this.scrollObj.width(60*this.lis.length+"px");//當(dāng)圖片數(shù)超出默認(rèn)值時,設(shè)置ul的寬度
                    this.btnL.click(function(){_this_.scrollRight();}).mouseover(function(){$(this).addClass("hover")}).mouseout(function(){$(this).removeClass("hover");});
                    this.btnR.click(function(){_this_.scrollLeft();}).mouseover(function(){$(this).addClass("hover")}).mouseout(function(){$(this).removeClass("hover");});;
                }
              };
        Zoom.prototype={
            scrollLeft:function(){
                if(Math.abs(this.l)==this.s){return};
                this.l--;
                this.scrollObj.animate({left:this.l*58+"px"},"fast");   
                },
            scrollRight:function(){
                if(this.l==0){return};
                this.l++;
                this.scrollObj.animate({left:this.l*58+"px"},"fast");
                },
            changeImgSrc:function(o){
                //改變標(biāo)識樣式
                $(o).addClass("selected").siblings().removeClass("selected");
                this.zoomArea.find("img").attr("src",$(o).find("img").attr("medium-img"));
                this.zoomDetailImg.attr("src",$(o).find("img").attr("medium-img"));

                },
            move:function(x,y){//鼠標(biāo)在放大區(qū)域移動的時候執(zhí)行的函數(shù)
                    this.XY=this.mousePosAndSetPos(x,y);//計算出鼠標(biāo)相對于放大區(qū)域的x,y值
                    //設(shè)置滑塊的位置
                    this.moveArea.css({
                                      left:this.XY.offsetX+"px",
                                      top:this.XY.offsetY+"px"
                                      });
                    //設(shè)置大圖在細(xì)節(jié)位置
                    this.zoomDetailImg.css({
                                           marginLeft:-this.XY.offsetX*this.moveBili+"px",
                                           marginTop:-this.XY.offsetY*this.moveBili+"px"
                                           });
                },
            mousePosAndSetPos:function(x,y){//實時計算并設(shè)置滑塊的位置
                x=x-this.zoomAreaOffset.left-this.moveArea.width()/2;
                y=y-this.zoomAreaOffset.top-this.moveArea.height()/2;
                x=x<0?0:x;
                y=y<0?0:y;
                x=x>(this.zoomAreaWidth-this.moveAreaWidth)?this.zoomAreaWidth-this.moveAreaWidth:x;
                y=y>(this.zoomAreaHeight-this.moveAreaHeight)?this.zoomAreaHeight-this.moveAreaHeight:y;
                return {
                        offsetX:x,
                        offsetY:y
                        };  
                },
            calculate:function(){//計算函數(shù)
                    var widthBili,heightBili;
                    //計算移動的滑塊與放大鏡鋪面顯示的比例寬高
                    widthBili=(this.zoomAreaWidth*this.zoomDetailWidth)/this.moveAreaWidth;
                    heightBili=(this.zoomAreaHeight*this.zoomDetailHeight)/this.moveAreaHeight;
                    //把比出來的寬高
                    this.zoomDetailImg.css({width:widthBili+"px",height:heightBili+"px"});
                    //返回移動的比例
                    this.moveBili=(widthBili-this.zoomDetailWidth)/(this.zoomAreaWidth-this.moveAreaWidth);
                }
            };
          var zoom=new Zoom($(".ZoomMain").eq(0));    
})();

相關(guān)文章

  • jQuery EasyUI編輯DataGrid用combobox實現(xiàn)多級聯(lián)動

    jQuery EasyUI編輯DataGrid用combobox實現(xiàn)多級聯(lián)動

    本文給大家分享jQuery EasyUI編輯DataGrid用combobox實現(xiàn)多級聯(lián)動效果的實例代碼,代碼簡單易懂,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧
    2016-08-08
  • JQuery datepicker 使用方法

    JQuery datepicker 使用方法

    jQuery UI很強大,其中的日期選擇插件Datepicker是一個配置靈活的插件,我們可以自定義其展示方式,包括日期格式、語言、限制選擇日期范圍、添加相關(guān)按鈕以及其它導(dǎo)航等
    2011-05-05
  • jQuery powerFloat萬能浮動層下拉層插件使用介紹

    jQuery powerFloat萬能浮動層下拉層插件使用介紹

    支持hover, click, focus以及無事件觸發(fā);支持多達(dá)12種位置的定位,出界自動調(diào)整;支持頁面元素加載,Ajax加載,下拉列表,提示層效果,tip類效果等;可自定義裝載容器;內(nèi)置UI不錯的裝載容器;支持鼠標(biāo)跟隨等。
    2010-12-12
  • jquery常用的12個小功能

    jquery常用的12個小功能

    12個jquery常用功能,極好的,分享給大家,幫助大家更好的進(jìn)行jQuery開發(fā),感興趣的小伙伴們可以參考一下
    2016-07-07
  • jquery 實現(xiàn)拖動文件上傳加載進(jìn)度條功能

    jquery 實現(xiàn)拖動文件上傳加載進(jìn)度條功能

    這篇文章主要介紹了jquery 實現(xiàn)拖動文件上傳加載進(jìn)度條功能,主要用到的是HTML5的ondrop事件,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-03-03
  • WordPress 照片lightbox效果的運用幾點

    WordPress 照片lightbox效果的運用幾點

    應(yīng)該大家都知曉lightbox這類燈箱效果了,它一般更多地被運用在網(wǎng)站照片的顯示上。當(dāng)然還有更推廣的應(yīng)用,如facebox這種更漂亮全面的效果。
    2009-06-06
  • jquery實現(xiàn)可拖動DIV自定義保存到數(shù)據(jù)的實例

    jquery實現(xiàn)可拖動DIV自定義保存到數(shù)據(jù)的實例

    這篇文章主要介紹了jquery實現(xiàn)可拖動DIV自定義保存到數(shù)據(jù),有需要的朋友可以參考一下
    2013-11-11
  • jQuery實現(xiàn)在textarea指定位置插入字符或表情的方法

    jQuery實現(xiàn)在textarea指定位置插入字符或表情的方法

    這篇文章主要介紹了jQuery實現(xiàn)在textarea指定位置插入字符或表情的方法,實例分析了jQuery操作表單元素的技巧,非常實用,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • jQuery對table表格進(jìn)行增刪改查

    jQuery對table表格進(jìn)行增刪改查

    這篇文章主要為大家詳細(xì)介紹了jQuery對table表格進(jìn)行增刪改查操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • jquery ztree實現(xiàn)樹的搜索功能

    jquery ztree實現(xiàn)樹的搜索功能

    這篇文章主要為大家詳細(xì)介紹了jquery ztree實現(xiàn)樹的搜索功能,zTree是利用 JQuery 的核心代碼,實現(xiàn)一套能完成大部分常用功能的Tree插件,對ztree感興趣的小伙伴們可以參考一下
    2016-02-02

最新評論