美文网首页
2018-12-01

2018-12-01

作者: 白羽之鹰 | 来源:发表于2018-12-01 18:16 被阅读0次

    JS实现放大镜功能

    网店中的商品都能放大查看细节,这里是放大功能的简单实现。。。。

    这个放大镜具有选择放大倍数的功能。

    效果:


    HTML部分:

    <!DOCTYPE html>

    <html>

    <head>

    <meta charset="utf-8" />

    <title></title>

    <link rel="stylesheet" href="css/lens.css" />

    <script type="text/javascript" src="js/lens.js" ></script>

    </head>

    <body>

    <div class="small">

    <span class="tobig"></span>

    <img src="img/1367482836394.jpg" />

    </div>

    <div class="big">

    <img src="img/1367482836394.jpg"/>

    </div>

    放大倍数:<input value="2" class="multiple"/><button class="set">设置</button>

    <div class="picc">

    <img src="img/1367482836394.jpg" class="pics"/>

    <img src="img/1370512282166.jpg" class="pics"/>

    <img src="img/1373337078811.jpg" class="pics"/>

    <img src="img/20131227141118_VPjfy.jpeg" class="pics"/>

    <img src="img/20151015011741324.png" class="pics"/>

    </div>

    </body>

    </html>

    CSS部分:

    *{

    margin: 0px;

    }

    .small img{

    width: 300px;

    height: 400px;

    }

    .small{

    width: 300px;

    height: 400px;

    }

    .big img{

    position: absolute;

    width: 600px;

    height: 800px;

    }

    .big{

    position: absolute;

    top: 8px;

    left: 310px;

    width: 300px;

    height: 400px;

    overflow: hidden;

    display: none;

    }

    .tobig{

    width: 150px;

    height: 200px;

    position: absolute;

    background-color: rgba(255,255,255,.4);

    cursor: move;

    display: none;

    }

    /***************底部可选图片*********************/

    .picc{

    position: relative;

    top: 9px;

    }

    .picc img{

    width: 60px;

    height: 50px;

    background-color: blue;

    }

    .picc img:hover{

    box-shadow: 0 0 5px 5px dodgerblue;

    }

    .picc img:active{

    box-shadow: 0 0 5px 5px blue;

    }

    .set:active{

    background-color: pink;

    border-radius: 8px;

    }

    JS部分:

    window.onload = function() {

    var osmall = document.getElementsByClassName("small")[0];

    var otobig = document.getElementsByClassName("tobig")[0];

    var obig = document.getElementsByClassName("big")[0];

    var osmallpic=document.getElementsByTagName("img")[0];

    var obigpic=document.getElementsByTagName("img")[1];

    //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~//

    var omultiple=document.getElementsByClassName("multiple")[0];

    var oset=document.getElementsByClassName("set")[0];

    osmall.onmouseout = function() {

    otobig.style.display = "none";

    obig.style.display = "none";

    }

    osmall.onmousemove = function(event) {

    otobig.style.display = "block";

    obig.style.display = "block";

    var oleft = event.clientX - otobig.offsetWidth / 2;

    var otop = event.clientY - otobig.offsetHeight / 2;

    if(oleft < 0) {

    oleft = 0;

    } else if(oleft > osmall.offsetWidth - otobig.offsetWidth) {

    oleft = osmall.offsetWidth - otobig.offsetWidth;

    }

    if(otop < 0) {

    otop = 0;

    } else if(otop > osmall.offsetHeight - otobig.offsetHeight) {

    otop = osmall.offsetHeight - otobig.offsetHeight;

    }

    var onumeral=omultiple.value;

    otobig.style.left = oleft + "px";

    otobig.style.top = otop + "px";

    obigpic.style.left=-(oleft*onumeral)+'px';

    obigpic.style.top=-(otop*onumeral)+'px';

    }

    //~~~~~~~~~~~~~~~~设置放大倍数~~~~~~~~~~~~~~~~~//

    oset.onclick=function(){

    var onumeral=omultiple.value;//获取放大的倍数

    var a=obigpic.width;//获取大图的宽度

    var b=osmallpic.width;//获取小图的宽度

    a=b*onumeral;//把大图放大到指定倍数

    document.getElementsByTagName("img")[1].style.width=a+'px';//放大宽度

    var c=obigpic.height;

    var d=osmallpic.height;

    c=d*onumeral;

    document.getElementsByTagName("img")[1].style.height=c+'px';//放大高度

    /**************改变tobig框的大小******************/

    //左边tobig框的宽度占左图的比例==右边展示框占右图的比例//

    var bili1=b/a;

    otobig.style.width=bili1*300+'px';

    var bili2=d/c;

    otobig.style.height=bili2*400+'px';

    }

    //改变图片路径

    var opics=document.getElementsByClassName("pics");

    opics[0].onclick=function(){

    osmallpic.src="img/1367482836394.jpg";

    obigpic.src="img/1367482836394.jpg";

    }

    opics[1].onclick=function(){

    osmallpic.src="img/1370512282166.jpg";

    obigpic.src="img/1370512282166.jpg";

    }

    opics[2].onclick=function(){

    osmallpic.src="img/1373337078811.jpg";

    obigpic.src="img/1373337078811.jpg";

    }

    opics[3].onclick=function(){

    osmallpic.src="img/20131227141118_VPjfy.jpeg";

    obigpic.src="img/20131227141118_VPjfy.jpeg";

    }

    opics[4].onclick=function(){

    osmallpic.src="img/20151015011741324.png";

    obigpic.src="img/20151015011741324.png";

    }

    };

    动态改变图片路径总感觉还能简化,还有一点,选中图片样式改变可以优化,在JS动态获取CSS属性有点绕,

    弄了有点久。哎~~。

    END.

    相关文章

      网友评论

          本文标题:2018-12-01

          本文链接:https://www.haomeiwen.com/subject/huyrcqtx.html