首頁 >web前端 >js教程 >JavaScript仿淘寶實現放大鏡效果的實例

JavaScript仿淘寶實現放大鏡效果的實例

黄舟
黄舟原創
2017-11-24 09:41:152596瀏覽

我們都知道放大鏡效果一般都是用於一些商城中的,列如每當我們打開淘寶,天貓等pc端時,看到心儀的物品時,點擊圖片時,便呈現出放大鏡的效果。在沒有去理解分析它的原理時,感覺非常的神奇,當真正地去接觸,也是非常好理解、在之前的文章我們也為大家介紹了JavaScript實現放大鏡的實例,今天我們帶大家介紹下JavaScript仿淘寶實現放大鏡效果的實例!

我們將整個佈局分成三個部分,第一部分為主題的小圖片,將他放在整個佈局的左上角;第二部分是下邊的圖片列表,直接跟在小圖片的下邊;最後一部分是放大鏡顯示部分,將其定位到小圖片的右邊。
 接著就是利用js加入基本事件(包括滑鼠的移入移出等)詳細的內用見如下程式碼

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title></title>
    <style>
        ul{
            list-style: none;
            padding: 0;
        }
        .zoom-box{
            width: 452px;
            position: relative;
        }
        .small-box{
            position: relative;
            border: 1px solid #ccc;
        }
        .small-box img{
            width: 100%;
            height: 100%;
        }
        .small-box .square{
            position: absolute;
            left: 0;
            top: 0;
            background: yellow;
            opacity: 0.5;
            /*display: none;*/
        }
        .small-box .mask{
            width: 100%;
            height: 100%;
            position: absolute;
            top: 0;
            left: 0;
        }
        .img-list ul::after{
            clear: both;
            content: &#39;&#39;;
            display: table;
        }
        .img-list ul li{
            float: left;
            margin: 0 10px;
            padding: 6px;
        }
        .img-list img{
            border: 2px solid transparent;
        }
        .img-list img.active{
            border: 2px solid red;
        }
        .big-box{
            position: absolute;
            top: 0;
            left: 100%;
            margin-left: 2px;
            border: 1px solid #cccccc;
            width: 500px;
            height: 500px;
            overflow: hidden;
            display: none;
        }
        .big-box img{
            position: absolute;
            top: 0;
            left: 0;
        }

    </style>
</head>
<body>
    <!-- 布局-->
    <div><!-- 容器-->
        <div><!-- 小图片容器-->
            <img src="../img/magnifier/m1.jpg" alt=""/>
            <div></div><!-- 鼠标选中框-->
            <div></div><!-- 鼠标悬浮位置-->
        </div>
        <div><!-- 图片列表-->
            <ul>
                <li><img src="../img/magnifier/s1.jpg" alt="" data-small="../img/magnifier/m1.jpg"
                         data-big="../img/magnifier/b1.jpg"/></li>
                <li><img src="../img/magnifier/s2.jpg" alt="" data-small="../img/magnifier/m2.jpg"
                         data-big="../img/magnifier/b2.jpg"/></li>
                <li><img src="../img/magnifier/s3.jpg" alt="" data-small="../img/magnifier/m3.jpg"
                         data-big="../img/magnifier/b3.jpg"/></li>
                <li><img src="../img/magnifier/s4.jpg" alt="" data-small="../img/magnifier/m4.jpg"
                         data-big="../img/magnifier/b4.jpg"/></li>
                <li><img src="../img/magnifier/s5.jpg" alt="" data-small="../img/magnifier/m5.jpg"
                         data-big="../img/magnifier/b5.jpg"/></li>
            </ul>
        </div>
        <div><!-- 放大镜-->
            <img src="../img/magnifier/b1.jpg" alt=""/>
        </div>
    </div>

    <script>
        //获取要操作的元素
        var smallbox = $(&#39;.small-box .mask&#39;);
        var smallimg = $(&#39;.small-box img&#39;);
        var square = $(&#39;.square&#39;);
        var bigbox = $(&#39;.big-box&#39;);
        var bigimg = $(&#39;.big-box img&#39;);
        var imgs = $all(&#39;.img-list img&#39;);

        //鼠标经过图片列表显示被选中,实现图片切换
        for(var i = 0; i < imgs.length; i++){
            imgs[i].onmouseover = function(){
                for(var j = 0; j < imgs.length; j++){
                    imgs[j].className = &#39;&#39;;
                }
                this.className = &#39;active&#39;;

                //改变对应的图片链接
                smallimg.src = this.getAttribute(&#39;data-small&#39;);
                bigimg.src = this.getAttribute(&#39;data-big&#39;);
            };
        }

        //鼠标移入放大器显示并设置选中框的大小
        smallbox.onmouseover = function(){
            square.style.display = &#39;block&#39;;
            bigbox.style.display = &#39;block&#39;;
            //位置w/smallimg.w = bigbox.w/bigimg.w
            square.style.width = bigbox.offsetWidth * smallimg.offsetWidth/bigimg.offsetWidth + &#39;px&#39;;
            square.style.height = bigbox.offsetHeight * smallimg.offsetHeight/bigimg.offsetHeight + &#39;px&#39;;
        };
        //鼠标移出放大器隐藏
        smallbox.onmouseout = function(){
            square.style.display = &#39;none&#39;;
            bigbox.style.display = &#39;none&#39;;
        };

        //放大器移动
        //获取鼠标的位置
        smallbox.onmousemove = function(ev){
            var oEvent = ev || event;
            var x = oEvent.offsetX - square.offsetWidth/2;
            var y = oEvent.offsetY - square.offsetHeight/2;

            if(x < 0){
                x = 0;
            }
            if(x > smallbox.offsetWidth - square.offsetWidth){
                x = smallbox.offsetWidth - square.offsetWidth;
            }
            if(y < 0){
                y = 0;
            }
            if(y > smallbox.offsetHeight - square.offsetHeight){
                y = smallbox.offsetHeight - square.offsetHeight;
            }

            //给选中框定位
            square.style.left = x + &#39;px&#39;;
            square.style.top = y + &#39;px&#39;;

            //给放大器定位  x/? = smallimg.w/bigimg.w
            bigimg.style.top = -y * bigimg.offsetWidth/smallimg.offsetWidth + &#39;px&#39;;
            bigimg.style.left = -x * bigimg.offsetHeight/smallimg.offsetHeight + &#39;px&#39;;

        };

        //通过名称查找某个元素
        function $(name){
            return document.querySelector(name);
        }
        //通过名称查找相同的一组数据
        function $all(name){
            return document.querySelectorAll(name);
        }
    </script>
</body>
</html>

總結:

到這裡這個放大鏡效果就完成了,相信小夥伴們對此也是有了自己的理解與認識,希望對你的工作有所幫助!

相關推薦:

#JavaScript實作放大鏡的效果的實例


用css實作圖片放大鏡效果實例詳解(圖)


##原生JS實作簡單放大鏡效果#

以上是JavaScript仿淘寶實現放大鏡效果的實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn