• jquery放大镜,可随意设置css


    /*放大镜*/
    .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:200px; height:200px;background:#000;opacity:0.2;filter:Alpha(Opacity=20);}
    .ZoomMain .zoomDetail{display:none;border:1px solid red;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*/
    <!--放大镜-->
    <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 hover"> <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="1347000569971.jpg" large-img="1347000569971.jpg" /></li>
                  </ul>
            </div>
      </div>
      <div class="zoomDetail">
                 <img src="1347000569971.jpg" />
      </div>
    </div>
    <!--放大镜end-->
    (function(){
            function Zoom(object){
                     this.zoomArea=$(".zoom",object);//保存促发放大效果的区域
                    this.moveArea=$(".move",object);//保存移动区域
                    this.zoomDetail=$(".zoomDetail",object);//保存放大镜区域
                    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();//初始化放大区域在视口中的相对偏移;
                    this.XY=null;//初始化鼠标相对于放大区域的偏移偏移值
                    this.moveBili=null;//
                    var _this_=this;
                    this.zoomArea.mousemove(function(e){//当鼠标在放大区域移动的时候执行
                                                     _this_.move(e.pageX,e.pageY);     
                                            }).mouseover(function(){
                                                _this_.moveArea.show();
                                                _this_.zoomDetail.show();
                                                }).mouseout(function(){
                                                    _this_.moveArea.hide();
                                                    _this_.zoomDetail.hide();                                                
                                                    });
                    this.calculate();//初始化并计算出
                  };
            Zoom.prototype={
                move:function(x,y){//鼠标在放大区域移动的时候执行的函数
                        this.XY=this.mousePosAndSetPos(x,y);//计算出鼠标相对于放大区域的x,y值
                        //设置滑块的位置
                        this.moveArea.css({
                                          left:this.XY.offsetX+"px",
                                          top:this.XY.offsetY+"px"
                                          });
                        //设置大图在细节位置
                        this.zoomDetailImg.css({
                                               marginLeft:-this.XY.offsetX*this.moveBili+"px",
                                               marginTop:-this.XY.offsetY*this.moveBili+"px"
                                               });
                    },
                mousePosAndSetPos:function(x,y){//实时计算并设置滑块的位置
                    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(){
                        var widthBili,heightBili;
                        //计算移动的滑块与放大镜铺面显示的比例宽高
                        widthBili=(this.zoomAreaWidth*this.zoomDetailWidth)/this.moveAreaWidth;
                        heightBili=(this.zoomAreaHeight*this.zoomDetailHeight)/this.moveAreaHeight;
                        //把比出来的宽高
                        this.zoomDetailImg.css({widthBili+"px",height:heightBili+"px"});
                        //返回移动的比例
                        this.moveBili=(widthBili-this.zoomDetailWidth)/(this.zoomAreaWidth-this.moveAreaWidth);
                    }
                };
              var zoom=new Zoom($(".ZoomMain").eq(0));
              
    })();
  • 相关阅读:
    BZOJ 3809 Gty的二逼妹子序列 莫队算法+分块
    BZOJ 3131 SDOI2013 淘金 数位dp
    BZOJ 4408 FJOI2016 神秘数 可持久化线段树
    [leetcode] Reverse Linked List
    走迷宫问题总结
    [leetcode] Max Area of Island
    [leetcode] All Paths From Source to Target
    [leetcode] Arithmetic Slices
    [leetcode] Move Zeroes
    [leetcode] Linked List Cycle
  • 原文地址:https://www.cnblogs.com/yangliulang/p/2756952.html
Copyright © 2020-2023  润新知