中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

原生JS怎么實現放大鏡效果

發布時間:2021-06-18 14:37:51 來源:億速云 閱讀:132 作者:小新 欄目:web開發

這篇文章給大家分享的是有關原生JS怎么實現放大鏡效果的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

具體內容如下

<html>

 <head>
 <meta charset="UTF-8">
 <title></title>
 <style type="text/css">
 * {
 margin: 0;
 padding: 0;
 }
 img{
 vertical-align: top;
 }
 .fdj {
 width: 350px;
 height: 350px;
 position: relative;
 margin: 100px auto;
 border: 1px solid gainsboro;
 }
 .small {
 position: relative;
 }
 .small img {
 width: 350px;
 }
 .mask {
 width: 100px;
 height: 100px;
 background: rgba(255, 255, 0, 0.4);
 position: absolute;
 left: 0;
 top: 0;
 cursor: move;
 display: none;
 }
 .big {
 position: absolute;
 top: 0;
 left: 360px;
 width: 500px;
 height: 500px;
 border: 1px solid gainsboro;
 overflow: hidden;
 display: none;
 }
 .big img{
 position: absolute;
 left: 0;
 top: 0;
 }
 </style>
 </head>

 <body>
 <div class="fdj">
 <div class="small">
 <img src="http://cdn.attach.qdfuns.com/notes/pics/201702/08/162503mw0fawb5b02va22i.jpg" />
 <div class="mask"></div>
 </div>
 <div class="big">
 <img src="http://cdn.attach.qdfuns.com/notes/pics/201702/08/162503mw0fawb5b02va22i.jpg" />
 </div>
 </div>
 </body>
 <script type="text/javascript">
 var fdj = document.querySelector('.fdj') // 獲得最大的盒子
 var small = document.querySelector('.small'); //獲取小圖片盒子
 var big = document.querySelector('.big'); //獲取大圖片盒子
 var bigs = big.children[0] //大圖片 
 var smalls = small.children[0] //小圖片
 var mask = small.children[1]; //遮罩

 //鼠標移入小圖片盒子
 small.onmouseover = function() {
 //鼠標移入圖片盒子將遮罩與大圖片顯示
 mask.style.display = 'block';
 big.style.display = ' block';
 };

 //鼠標移出小圖片盒子
 small.onmouseout = function() {
 //鼠標移出小圖片盒子將遮罩與大圖片隱藏
 mask.style.display = 'none';
 big.style.display = 'none';
 };

 var x=0;
 var y=0;
 //鼠標在小圖片上移動時
 small.onmousemove = function(ev) {
 var ev = event || window.event;
 //讓鼠標在遮罩正中
 //鼠標X坐標與Y坐標
 x = ev.clientX -this.offsetParent.offsetLeft- mask.offsetWidth / 2 ; 
 y = ev.clientY -this.offsetParent.offsetTop- mask.offsetHeight / 2 ;
 //將遮罩限制在小圖片盒子中

 if (x<0) {
 x=0;
 }else if(x>small.offsetWidth-mask.offsetWidth){
 x = small.offsetWidth-mask.offsetWidth;
 }

 if(y<0){
 y=0;
 }else if(y>small.offsetHeight-mask.offsetHeight){
 y= small.offsetHeight-mask.offsetHeight
 }
 mask.style.left = x + 'px';
 mask.style.top = y + 'px';

 //大圖與小圖的比例

 /*var scalX = bigs.offsetWidth/small.offsetWidth;
 var scalY = bigs.offsetHeight/small.offsetHeight;*/

 var scalX = x/(small.offsetWidth-mask.offsetWidth);
 var scalY = y/(small.offsetHeight-mask.offsetHeight);

 bigs.style.left = -(x*scalX)+'px';
 bigs.style.top = -(y*scalY)+'px';

 };

 </script>

</html>

效果圖:(演示)

原生JS怎么實現放大鏡效果

感謝各位的閱讀!關于“原生JS怎么實現放大鏡效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

临汾市| 阿瓦提县| 攀枝花市| 康乐县| 普安县| 寿宁县| 双城市| 祥云县| 汝南县| 安顺市| 奉新县| 德格县| 裕民县| 英吉沙县| 茌平县| 大理市| 灯塔市| 谷城县| 安多县| 鹿泉市| 阳曲县| 仪征市| 涡阳县| 定陶县| 洮南市| 双鸭山市| 桦甸市| 北川| 什邡市| 普宁市| 金华市| 融水| 蒙阴县| 连山| 宜都市| 安图县| 汉阴县| 天长市| 铜川市| 北票市| 汤阴县|