JavaScript 图片放大看!- 放大镜效果 -鼠标放在图片上某个点:出现放大效果的图片


 


1张图片-放大镜:

缺点:1张图片若为小图,小图放大后图像不清晰(若为大图,则不存在这个问题)
<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title> 1张图片 放大镜:</title>
    <style>
        /*    reset  css  样式重置 */
        body,p,pre,h1,h2,h3,h4,h5,h6,ul,ol,li,dl,dt,dd,table,tr,td,div,img,form,fieldset,select,textarea,input{
            margin: 0;
            padding: 0;
        }
        body{font-size:16px;}
        table{border-collapse: collapse;}
        select,textarea,input{outline:none;  border: none; background:#fff;  }
        textarea{ resize: none; overflow: auto}
        a{  text-decoration: none;}
        li{ list-style: none; vertical-align: top}
        img{ border:none; vertical-align: top}
        /*  end  reset  css     */
        .wrap{
            position: relative;
            height: 400px;  width: 850px; margin:100px  0  0  400px   ;
            background: #ccc;
        }
        .wrap .smallImg,  .wrap .bigImg{
            position: absolute;
            top: 0;
            width: 400px;   height: 400px;   outline: 2px solid red;
            overflow: hidden;
        }
        .wrap .smallImg{
            left: 0;}
        .wrap .bigImg{
            left: 450px;
            display: none;
         }
        .wrap .bigImg img{
            position: absolute;
            left: 0;
            top: 0;
        }
        #shadow{
            position: absolute;
            left: 0;
            top: 0;
            display: none;
            width: 100px;
            height: 100px;background: rgba(0,0,255,0.5)}


    </style>

    <script>
        window.onload = function(){

            var wrap    = document.getElementsByClassName("wrap")[0];
            var smallImgBox = wrap.getElementsByClassName("imgBox")[0];
            var smallImg = smallImgBox.getElementsByTagName("img")[0];
            var bigImgBox = wrap.getElementsByClassName("imgBox")[1];
            var bigImg = bigImgBox.getElementsByTagName("img")[0];
            var shadow = document.getElementById("shadow")

            smallImgBox.onmouseover = function () {
                shadow.style.display="block";
                bigImgBox.style.display="block";
            };
             smallImgBox.onmouseout = function () {
                 shadow.style.display="none";
                 bigImgBox.style.display="none";
             }

            smallImgBox.onmousemove = function (ev) {
                var ev = ev || window.event ;
                var x =  ev.clientX  -   smallImgBox.offsetLeft - wrap.offsetLeft   ;
                var y = ev.clientY  -    smallImgBox.offsetTop  -wrap.offsetTop;

                var l = x-shadow.offsetWidth/2 ;
                var t = y -shadow.offsetHeight/2 ;

                if( l <=0 ) { l=0; }
                else if(  l >=smallImgBox.offsetWidth - shadow.offsetWidth ){
                    l = smallImgBox.offsetWidth - shadow.offsetWidth ;
                }
                if(  t <=0 ){  t=0; }
                else if(  t>=smallImgBox.offsetHeight - shadow.offsetHeight )  {
                    t=   smallImgBox.offsetHeight - shadow.offsetHeight;
                }
                shadow.style.left= l +"px";
                shadow.style.top= t +"px";

               var  radioX = l /   (smallImgBox.offsetWidth - shadow.offsetWidth);
                var  radioY = t /  (smallImgBox.offsetHeight - shadow.offsetHeight) ;
                document.title =radioX+" "+ radioY ;
                bigImg.style.left=-radioX*(bigImg.width - bigImgBox.offsetWidth) +"px";
                bigImg.style.top=-radioY*(bigImg.height - bigImgBox.offsetHeight) +"px";



/*               var  radioX = x /  (smallImgBox.offsetWidth - shadow.offsetWidth)  >=1? 1 : x /   (smallImgBox.offsetWidth - shadow.offsetWidth) ;
                var  radioY = y /  (smallImgBox.offsetHeight - shadow.offsetHeight) >=1? 1 :  y /  (smallImgBox.offsetHeight - shadow.offsetHeight);
                document.title =radioX+" "+ radioY ;
                bigImg.style.left=-radioX*(bigImg.width - bigImgBox.offsetWidth) +"px";
                bigImg.style.top=-radioY*(bigImg.height - bigImgBox.offsetHeight) +"px";*/

            };
        };
    </script>

</head>
<body>
<div class="wrap">
    <div class="smallImg imgBox">
        <img src="images/bimg.jpg" width="400" alt="chothes"/>
        <div id="shadow"> </div>
    </div>
    <div class="bigImg imgBox">
        <img src="images/bimg.jpg" width="800" alt="chothes"/>
    </div>
</div>
</body>
</html>

  

2张图片-放大镜

缺点:素材需要一张小图,一张大图共计两张图
<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title> 2张图片- 放大镜</title>
    <style>
        /*    reset  css  样式重置 */
        body,p,pre,h1,h2,h3,h4,h5,h6,ul,ol,li,dl,dt,dd,table,tr,td,div,img,form,fieldset,select,textarea,input{
            margin: 0;
            padding: 0;
        }
        body{font-size:16px;}
        table{border-collapse: collapse;}
        select,textarea,input{outline:none;  border: none; background:#fff;  }
        textarea{ resize: none; overflow: auto}
        a{  text-decoration: none;}
        li{ list-style: none; vertical-align: top}
        img{ border:none; vertical-align: top}
        /*  end  reset  css     */
        .wrap{
            position: relative;
            height: 400px;  width: 850px; margin:100px  0  0  400px   ;
            background: #ccc;
        }
        .wrap .smallImg,  .wrap .bigImg{
            position: absolute;
            top: 0;
            width: 400px;   height: 400px;   outline: 2px solid red;
            overflow: hidden;
        }
        .wrap .smallImg{
            left: 0;}
        .wrap .bigImg{
            left: 450px;
            display: none;
        }
        .wrap .bigImg img{
            position: absolute;
            left: 0;
            top: 0;
        }
        #shadow{
            position: absolute;
            left: 0;
            top: 0;
            display: none;
            width: 100px;
            height: 100px;background: rgba(0,0,255,0.5)}


    </style>

    <script>
        window.onload = function(){

            var wrap    = document.getElementsByClassName("wrap")[0];
            var smallImgBox = wrap.getElementsByClassName("imgBox")[0];
            var smallImg = smallImgBox.getElementsByTagName("img")[0];
            var bigImgBox = wrap.getElementsByClassName("imgBox")[1];
            var bigImg = bigImgBox.getElementsByTagName("img")[0];
            var shadow = document.getElementById("shadow")

            smallImgBox.onmouseover = function () {
                shadow.style.display="block";
                bigImgBox.style.display="block";
            };
            smallImgBox.onmouseout = function () {
                shadow.style.display="none";
                bigImgBox.style.display="none";
            }


            smallImgBox.onmousemove = function (ev) {

                var ev = ev || window.event ;

                //鼠标在指定div里面的坐标:可视区里面鼠标坐标- div到文档边界的距离
              /*  var x =  ev.clientX  -   shadow.offsetParent.offsetLeft -shadow.offsetParent.offsetParent.offsetLeft   ;
                var y = ev.clientY  -    shadow.offsetParent.offsetTop  -shadow.offsetParent.offsetParent.offsetLeft;*/
                var x =  ev.clientX  -   smallImgBox.offsetLeft - wrap.offsetLeft   ;
                var y = ev.clientY  -    smallImgBox.offsetTop  -wrap.offsetTop;


                var l = x-shadow.offsetWidth/2 ;
                var t = y -shadow.offsetHeight/2 ;

                if( l <=0 ) { l=0; }
                else if(  l >=smallImgBox.offsetWidth - shadow.offsetWidth ){
                    l = smallImgBox.offsetWidth - shadow.offsetWidth ;
                }
                if(  t <=0 ){  t=0; }
                else if(  t>=smallImgBox.offsetHeight - shadow.offsetHeight )  {
                    t=smallImgBox.offsetHeight - shadow.offsetHeight;
                }
                shadow.style.left= l +"px";
                shadow.style.top= t +"px";

              /*  var  radioX = l /   (smallImgBox.offsetWidth - shadow.offsetWidth);
                var  radioY = t /  (smallImgBox.offsetHeight - shadow.offsetHeight) ;
                document.title =radioX+" "+ radioY ;
                bigImg.style.left=-radioX*(bigImg.width - bigImgBox.offsetWidth) +"px";
                bigImg.style.top=-radioY*(bigImg.height - bigImgBox.offsetHeight) +"px";*/

                 var  radioX = x /  (smallImgBox.offsetWidth - shadow.offsetWidth)  >=1? 1 : x /   (smallImgBox.offsetWidth - shadow.offsetWidth) ;
                 var  radioY = y /  (smallImgBox.offsetHeight - shadow.offsetHeight) >=1? 1 :  y /  (smallImgBox.offsetHeight - shadow.offsetHeight);
                 document.title =radioX+" "+ radioY ;
                 bigImg.style.left=-radioX*(bigImg.width - bigImgBox.offsetWidth) +"px";
                 bigImg.style.top=-radioY*(bigImg.height - bigImgBox.offsetHeight) +"px";

            };
        };
    </script>

</head>
<body>
<div class="wrap">
    <div class="smallImg imgBox">
        <img src="images/simg.jpg" width="400" alt="chothes"/>
        <div id="shadow"> </div>
    </div>
    <div class="bigImg imgBox">
        <img src="images/bimg.jpg" width="800" height="800" alt="chothes"/>
    </div>
</div>
</body>
</html>

  

3 大图作为背景图片 - 放大镜
缺点:需要知道背景图片数字大小不像前面两者能获取img样式宽高
<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title> 2张图片- 放大镜</title>
    <style>
        /*    reset  css  样式重置 */
        body,p,pre,h1,h2,h3,h4,h5,h6,ul,ol,li,dl,dt,dd,table,tr,td,div,img,form,fieldset,select,textarea,input{
            margin: 0;
            padding: 0;
        }
        body{font-size:16px;}
        table{border-collapse: collapse;}
        select,textarea,input{outline:none;  border: none; background:#fff;  }
        textarea{ resize: none; overflow: auto}
        a{  text-decoration: none;}
        li{ list-style: none; vertical-align: top}
        img{ border:none; vertical-align: top}
        /*  end  reset  css     */
        .wrap{
            position: relative;
            height: 400px;  width: 850px; margin:100px  0  0  400px   ;
            background: #ccc;
        }
        .wrap .smallImg,  .wrap .bigImg{
            position: absolute;
            top: 0;
            width: 400px;   height: 400px;   outline: 2px solid red;
            overflow: hidden;
        }
        .wrap .smallImg{
            left: 0;}
        .wrap .bigImg{
            left: 450px;
            display: none;
            background: url("images/bimg.jpg") no-repeat 0 0 ;
        }
        .wrap .bigImg img{
            position: absolute;
            left: 0;
            top: 0;
        }
        #shadow{
            position: absolute;
            left: 0;
            top: 0;
            display: none;
            width: 100px;
            height: 100px;background: rgba(0,0,255,0.5)}


    </style>

    <script>
        window.onload = function(){

            var wrap    = document.getElementsByClassName("wrap")[0];
            var smallImgBox = wrap.getElementsByClassName("imgBox")[0];
            var smallImg = smallImgBox.getElementsByTagName("img")[0];
            var bigImgBox = wrap.getElementsByClassName("imgBox")[1];
            var bigImg = bigImgBox.getElementsByTagName("img")[0];
            var shadow = document.getElementById("shadow")

            smallImgBox.onmouseover = function () {
                shadow.style.display="block";
                bigImgBox.style.display="block";
            };
            smallImgBox.onmouseout = function () {
                shadow.style.display="none";
                bigImgBox.style.display="none";
            }


            smallImgBox.onmousemove = function (ev) {

                var ev = ev || window.event ;

                //鼠标在指定div里面的坐标:可视区里面鼠标坐标- div到文档边界的距离
              /*  var x =  ev.clientX  -   shadow.offsetParent.offsetLeft -shadow.offsetParent.offsetParent.offsetLeft   ;
                var y = ev.clientY  -    shadow.offsetParent.offsetTop  -shadow.offsetParent.offsetParent.offsetLeft;*/
                var x =  ev.clientX  -   smallImgBox.offsetLeft - wrap.offsetLeft   ;
                var y = ev.clientY  -    smallImgBox.offsetTop  -wrap.offsetTop;


                var l = x-shadow.offsetWidth/2 ;
                var t = y -shadow.offsetHeight/2 ;

                if( l <=0 ) { l=0; }
                else if(  l >=smallImgBox.offsetWidth - shadow.offsetWidth ){
                    l = smallImgBox.offsetWidth - shadow.offsetWidth ;
                }
                if(  t <=0 ){  t=0; }
                else if(  t>=smallImgBox.offsetHeight - shadow.offsetHeight )  {
                    t=smallImgBox.offsetHeight - shadow.offsetHeight;
                }
                shadow.style.left= l +"px";
                shadow.style.top= t +"px";

              /*
               var  radioX = x /  (smallImgBox.offsetWidth - shadow.offsetWidth)  >=1? 1 : x /   (smallImgBox.offsetWidth - shadow.offsetWidth) ;
               var  radioY = y /  (smallImgBox.offsetHeight - shadow.offsetHeight) >=1? 1 :  y /  (smallImgBox.offsetHeight - shadow.offsetHeight);
               document.title =radioX+" "+ radioY ;
               bigImg.style.left=-radioX*(bigImg.width - bigImgBox.offsetWidth) +"px";
               bigImg.style.top=-radioY*(bigImg.height - bigImgBox.offsetHeight) +"px";
              */

                var  radioX = l /   (smallImgBox.offsetWidth - shadow.offsetWidth);
                var  radioY = t /  (smallImgBox.offsetHeight - shadow.offsetHeight) ;
                document.title =radioX+" "+ radioY ;


                /* 背景图片缺点:  这里需要知道背景图片具体大小-数字 800*800  */
                bigImgBox.style.backgroundPositionX=-radioX*( 800- bigImgBox.offsetWidth) +"px";
                bigImgBox.style.backgroundPositionY=-radioY*( 800- bigImgBox.offsetHeight) +"px";

            };
        };
    </script>

</head>
<body>
<div class="wrap">
    <div class="smallImg imgBox">
        <img src="images/simg.jpg" width="400" alt="chothes"/>
        <div id="shadow"> </div>
    </div>
    <div class="bigImg imgBox">
      <!--  <img src="images/bimg.jpg" width="800" height="800" alt="chothes"/>-->
    </div>
</div>
</body>
</html>

  





posted @ 2016-08-25 19:48  July_Zheng  阅读(346)  评论(0编辑  收藏  举报