• 技术文章 >web前端 >js教程

    基于jquery的放大镜效果_jquery

    2016-05-16 17:53:08原创635
    核心代码:
    复制代码 代码如下:

    $(function(){
    var mouseX = 0; //鼠标移动的位置X
    var mouseY = 0; //鼠标移动的位置Y
    var maxLeft = 0; //最右边
    var maxTop = 0; //最下边
    var markLeft = 0; //放大镜移动的左部距离
    var markTop = 0; //放大镜移动的顶部距离
    var perX = 0; //移动的X百分比
    var perY = 0; //移动的Y百分比
    var bigLeft = 0; //大图要移动left的距离
    var bigTop = 0; //大图要移动top的距离
    //改变放大镜的位置
    function updataMark($mark){
    //通过判断,让小框只能在小图区域中移动
    if(markLeft<0){
    markLeft = 0;
    }else if(markLeft>maxLeft){
    markLeft = maxLeft;
    }

    if(markTop<0){
    markTop = 0;
    }else if(markTop>maxTop){
    markTop = maxTop;
    }
    //获取放大镜的移动比例,即这个小框在区域中移动的比例
    perX = markLeft/$(".small").outerWidth();
    perY = markTop/$(".small").outerHeight();
    bigLeft = -perX*$(".big").outerWidth();
    bigTop = -perY*$(".big").outerHeight();
    //设定小框的位置
    $mark.css({"left":markLeft,"top":markTop,"display":"block"});
    }
    //改变大图的位置
    function updataBig(){
    $(".big").css({"display":"block","left":bigLeft,"top":bigTop});
    }
    //鼠标移出时
    function cancle(){
    $(".big").css({"display":"none"});
    $(".mark").css({"display":"none"});
    }
    //鼠标小图上移动时
    function imgMouseMove(event){
    var $this = $(this);
    var $mark = $(this).children(".mark");
    //鼠标在小图的位置
    mouseX = event.pageX-$this.offset().left - $mark.outerWidth()/2;
    mouseY = event.pageY-$this.offset().top - $mark.outerHeight()/2;
    //最大值
    maxLeft =$this.width()- $mark.outerWidth();
    maxTop =$this.height()- $mark.outerHeight();
    markLeft = mouseX;
    markTop = mouseY;
    updataMark($mark);
    updataBig();
    }

    $(".small").bind("mousemove",imgMouseMove).bind("mouseleave",cancle);
    })


    这个里面主要有二点

    1.如何大图跟随"放大镜"的位置,同时移动大图?

    其实就是用到一个比例关系,当“放大镜”移动多少比例(是比例,不是具体值),大图也同时用这个比例去乘以大图的宽和高,就可以算出大图该移动多少距离了;

    2.显示区域和放大镜的关系?

    这里的“放大镜”应该和大图的显示区域的比例,应该是大图和小的比例关系一样。比如大图和小图的比例是1:2,那个“放大镜”区域的大小,和显示大图区域的大小比例也应该是1:2,不然“放大镜”罩住的小图区域,和大图的显示区域,所显示的图像信息,不能保持一致。(妙味课堂里讲的那个实例,就是没有保持一至);

    在线演示:http://demo.jb51.net/js/2012/mymagnifier/
    打包下载:http://www.jb51.net/jiaoben/45315.html
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:jquery 放大镜
    上一篇:js动态在form上插入enctype=multipart/form-data的问题_表单特效 下一篇:javascript中break,continue和return语句用法小结_javascript技巧
    PHP编程就业班

    相关文章推荐

    • 帮你搞定JavaScript对象• 带你了解JavaScript解构赋值• javascript数据类型学习之浅析Symbol类型• JavaScript中如何获取URL参数?4种常见方法详解• 什么是hook?聊聊React中常用的两个Hook

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网