利用HTML5 与CSS3 做的放大镜

  1. html结构

    <div class="wrap">
    <div class="move">
    <ul class="pic">
    <li><img src="img/iBannerText.png" /></li>
    <li><img src="img/iBannerText2.png" /></li>
    <li><img src="img/iBannerText3.png" /></li>
    </ul>
    <div class="zoomPic">
    <div class="mask_pic">
    <div class="pic">
    </div>
    <div class="mask">
    </div>
    </div>
    </div>
    </div>
    <ul class="text">
    <li><img src="img/iCourseTabText.png" /></li>
    <li><img src="img/iCourseTabText2.png" /></li>
    <li><img src="img/iCourseTabText3.png" /></li>
    </ul>
    <ul class="botton">
    <li class="active"><span></span></li>
    <li><span></span></li>
    <li><span></span></li>
    </ul>
    </div>
  2. 样式
    body,
    ul,
    li {
    padding: 0;
    margin: 0;
    } ul {
    list-style: none;
    } .wrap {
    margin: 50px auto;
    width: 365px;
    position: relative;
    border: 2px solid firebrick;
    vertical-align: center;
    } .wrap .pic {
    position: relative;
    height: 80px;
    width: 100%;
    } .wrap .pic li {
    position: absolute;
    top: -80px;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    opacity: 0;
    } .wrap .text {
    position: relative;
    top: 0px;
    left: 0;
    height: 45px;
    width: 100%;
    margin-top: 30px;
    } .wrap .text li {
    position: absolute;
    left: 365px;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    opacity: 0;
    } .wrap .botton {
    position: relative;
    bottom: 0px;
    height: 21px;
    right: 0px;
    width: 75px;
    left: 280px;
    } .wrap .botton li {
    float: left;
    height: 100%;
    width: 20px;
    margin: 0px 5px 0px 0px;
    background-image: url(img/iCourseTabBtnShadow.png);
    background-repeat: no-repeat;
    } .wrap .botton span {
    display: block;
    height: 100%;
    background-position: center 2px;
    background-repeat: no-repeat;
    background-image: url(img/iCourseIco.png);
    -webkit-transform: scale(0);
    transform: scale(0);
    transition: 0.3s;
    } .wrap .botton .active span {
    -webkit-transform: scale(1);
    transform: scale(1);
    } .zoomPic {
    position: absolute;
    height: 172px;
    width: 144px;
    top: 0px;
    left: -85px;
    background-image: url(img/iZoom.png);
    background-repeat: no-repeat;
    overflow: hidden;
    top: -13px;
    -webkit-transform-origin: 6px 166px;
    /*-webkit-transform: rotate(-30deg);*/
    transition: 0.3s;
    }
    .zoomPic .mask_pic{
    height: 96px;
    width: 96px;
    position: absolute;
    left: 43px;
    top: 3px;
    background-color: #FFFFFF;
    border-radius: 50%;
    }
    .zoomPic .pic {
    position: absolute;
    height: 96px;
    width: 96px;
    background-image: url(img/iBannerTextBig.png);
    background-repeat: no-repeat;
    left: 0px;
    top: 0;
    border-radius: 50%;
    background-position: 40px 0px;
    transition: 0.5s linear;
    /*相对于 zoomPic 的旋转基点*/
    -webkit-transform-origin:-36px 165px ;
    /*-webkit-transform: rotate(30deg);*/
    } .zoomPic .mask {
    border-radius: 50%;
    position: absolute;
    left: 0px;
    top: 0;
    height: 96px;
    width: 96px;
    background-image: url(img/iZoomGlass.png);
    background-repeat: no-repeat;
    }
    .move{
    position: relative;
    z-num: 5;
    }

     

  3.  伟大的js来了

    <script>
    $(function() {
    var btnList = $(".botton").find('li');
    var picList = $('.pic').find('li');
    var textList = $('.text').find('li');
    var num = 0
    var aSrc = ["img/iBannerTextBig.png", "img/iBannerTextBig2.png", "img/iBannerTextBig3.png"];
    //初始化
    picList.eq(0).css({
    'top': 0,
    'opacity': 1
    });
    textList.eq(0).css({
    'left': 0,
    'opacity': 1
    }) btnList.bind('click', function() {
    num = $(this).index();
    $(btnList).removeClass("active");
    $(this).addClass('active');
    //先移动放大镜
    toScale();
    //toHidden(num);
    //end(num); })
    //初始化
    zoomMove(0);
    //放大镜
    $('.move').bind('mousemove', function(ev) {
    var picL = $(this).offset().left;
    var picT = $(this).offset().top;
    var w = $(this).width();
    var H=$(this).height();
    var evX = ev.clientX;
    var evY = ev.clientY ;
    if(evX>=picL && (picL + w>=evX) &&(picT+H >=evY)){
    zoomMove(evX - picL);
    }else{
    //当鼠标 不在移动的范围时 回到原位置
    setTimeout(function(){
    zoomMove(0);
    },500)
    } }) function toScale(){
    $('.zoomPic').css({
    'webkitTransform':'rotate(-60deg)'
    })
    $('.zoomPic .pic').css({
    'webkitTransform':'rotate(60deg)'
    }) $('.zoomPic .pic').bind('webkitTransitionEnd',function(){
    //切换背景图片
    $(this).css({
    'backgroundImage':'url('+aSrc[num]+')'
    })
    /*=============*/
    $(this).unbind("webkitTransitionEnd");
    toHidden(num);
    })
    }
    function zoomMove(x) {
    //放大镜中心得位置
    var centerX = 96;
    var xScale = (424/363).toFixed(2) ;
    var picW = $('.mask_pic >.pic').width();
    console.log(picW)
    $('.mask_pic > .pic').css({
    'backgroundPosition' : -xScale*x+picW/2+"px 0px"
    }) $(".zoomPic").css({
    'webkitTransition':'0s', /// 这里 记得去除 不然会影放大镜移动的速度
    'left': x-centerX
    })
    }
    //图片及文字的隐藏
    function toHidden(){
    picList.css({
    "webkitTransition": '0.5s',
    "top": -80,
    "opacity": 0
    });
    textList.css({
    "webkitTransition": "0.3s top ,0.3s 0.2s left, 0.3s opacity",
    "top": 45,
    'left': 365,
    'opacity': 0
    })
    picList.bind('webkitTransitionEnd',picShow);
    textList.bind('webkitTransitionEnd', textShow);
    } function picShow(){
    picList.unbind('webkitTransitionEnd');
    $(picList[num]).css({
    'top': 0,
    'opacity': 1
    })
    //移除事件
    $(picList[num]).unbind('webkitTransitionEnd');
    }
    function textShow(){
    textList.unbind('webkitTransitionEnd');
    $(textList[num]).css({
    'top': 0,
    'left': 0,
    'opacity': 1
    })
    //放大镜还原的位置
    $(textList[num]).bind('webkitTransitionEnd',toOrigin)
    }
    function toOrigin(){
    $('.zoomPic').css({
    "webkitTransition": '0.5s',
    'webkitTransform':'rotate(0deg)'
    })
    $('.zoomPic .pic').css({
    "webkitTransition": '0.5s',
    'webkitTransform':'rotate(0deg)'
    })
    $(this).unbind('webkitTransitionEnd');
    }
    })
    </script>

    这就是惊天的成果 — _ *  2016-11-05  23:29:52

利用HTML5 与CSS3 做的放大镜的更多相关文章

  1. 利用html5的localStorage做一个备忘录

    实现一个便签功能,可以记录内容和写的时间,当网页从新载入,可以读取以前的记录. html文档 <!DOCTYPE html> <html> <head lang=&quo ...

  2. 利用HTML5和css3 选中图片上传到服务器,插件地址如下

    https://yusi123.com/3349.html 分三步,需要将js文件和css文件拷贝到项目目录下,在需要选择的图片的文件中引入,然后将HTML代码复制 <!--选择图片模块star ...

  3. <HTML5和CSS3响应式WEB设计指南>译者序

    "不是我不明白,这世界变化快."崔健的这首歌使用在互联网领域最合适不过.只短短数年的功夫,互联网的浪潮还没过去,移动互联网的时代已经来临.人们已经习惯将越来越多的时间花在各种移动设 ...

  4. 三款精美的html5及css3的源码插件

    1.HTML5 3D爱心动画 晚来的七夕礼物 七夕情人节刚过,今天小编却在国外的网站上看到一个利用HTML5和CSS3制作的3D爱心动画,莫非老外也过七夕?当然小编还是将这款HTML5 3D爱心动画收 ...

  5. 微信浏览器是移动端的IE6?微信升级内核后Html5和CSS3兼容性总结

    今年4月,自从微信浏览器X5 升级Blink内核之后,各前端社区一片高潮,仿佛看到了前端er,眼含热泪进而抱头痛头的说:终于可以不用兼容这"移动端的IE6 "了,可以早点回家了!! ...

  6. 《HTML5与CSS3实例教程》

    <HTML5与CSS3实例教程> 基本信息 作者: (美)Brian P. Hogan 译者: 卢俊祥 丛书名: 图灵程序设计丛书 出版社:人民邮电出版社 ISBN:97871153634 ...

  7. iOS Web应用开发:运用HTML5、CSS3与JavaScript

    <iOS Web应用开发:运用HTML5.CSS3与JavaScript> 基本信息 原书名:Pro iOS web design and development:HTML5, CSS3, ...

  8. 一起感受HTML5和CSS3

    Web设计师可以使用HTML4和CSS2.1完成一些很酷的东西.我们可以在不使用陈旧的基于table布局的基础上完成文档逻辑结构并创建内容丰富的网站.我们可以在不使用内联<font>和&l ...

  9. HTML5与CSS3知识点总结

    好好学习,天天向上 本文已收录至我的Github仓库DayDayUP:github.com/RobodLee/DayDayUP,欢迎Star 原文链接:https://blog.csdn.net/we ...

随机推荐

  1. const指针和指向const的指针

    int *const p=&a; 这是const指针,这种指针必须在定义时就给出它所指向的地址,否则会error:uninitialized const 'p'.const指针的指针本身是co ...

  2. 线程存储(Thread Specific Data)

    线程中特有的线程存储, Thread Specific Data .线程存储有什么用了?他是什么意思了? 大家都知道,在多线程程序中,所有线程共享程序中的变量.现在有一全局变量,所有线程都可以使用它, ...

  3. 修改dedecms 列表页上一页 下一页 方法!

    dedecms根目录下include文件夹下:arc.listview.class.php文件! 1.简单文字替换:如 上一页替换成上页,直接替换即可! 2.文字替换成图片:上一页替换成<img ...

  4. 异步通信rabbitmq——消息重试

    目标: 利用RabbitMQ实现消息重试和失败处理,实现可靠的消费消费.在消息消费异常时,自动延时将消息重试,当重试超过一定次数后,则列为异常消息,等待后续特殊处理. 准备: TTL:Time-To- ...

  5. 在winform下实现左右布局多窗口界面的方法(二)

    这篇文章主要介绍了在winform下实现左右布局多窗口界面的方法之续篇 的相关资料,需要的朋友可以参考下 在上篇文章在winform下实现左右布局多窗口界面的方法(一)已经实现了左右布局多窗口界面,今 ...

  6. Weblogic-unable to get file lock, will retry …问题解决

    weblogic部署应用出现如下报错: <2017-8-15 下午05时08分44秒 CST> <Info> <Management> <BEA-141281 ...

  7. 在阿里云服务器上安装git

    https://git-scm.com/book/zh/v1/%E8%B5%B7%E6%AD%A5-%E5%AE%89%E8%A3%85-Git 有yum的系统执行下列命令(已测试) $ yum in ...

  8. Windows命令查看文件的MD5/SHA1/SHA256

    certutil -hashfile "D:\Tools\Microsoft\SqlServer\2016\ct_sql_server_2016_enterprise_x64_dvd_869 ...

  9. [转】LTE整体架构和协议架构概述

    1.1 LTE整体架构 LTE(Long Term Evolution,长期演进)是由3GPP(The 3rd Generation Partnership Project,第三代合作伙伴计划)组织制 ...

  10. Python Django框架 补充

    Django REST framework ORM框架整理 Django框架 app间互借models字段的操作 ORM数据库操作补充:models中的一对一操作.过滤.事务 Django model ...