亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript實現商品圖片放大鏡

 更新時間:2019年11月28日 14:36:53   作者:Maybion  
這篇文章主要為大家詳細介紹了javascript實現商品圖片放大鏡,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

優(yōu)化原因

現在的電商商城項目解決的主要是購買商品的問題,那么購買商品主要要看清楚商品表面外形的主要特征和細節(jié),如果圖片處理過小,或者細節(jié)過于模糊,就需要做一個商品高清圖片放大局部的功能。

技術關鍵點

1.左側和上側距離,在一個水平位置和垂直位置中有我們可以挪動的區(qū)域,就是原圖片區(qū)域,鼠標挪動位置是一個塊狀位置,他的左側和上側距離瀏覽器上側和左側分別有一個長度,我們叫它們 ClientX 和 ClientY,而左上側鼠標沒有略過的位置實際上是一個點,我們拖動放大塊時,它會由一個點變成一個方塊,這個放大鏡左上邊的點所控制的這一點距離屏幕上側和左側的 ClientY 和 ClientX 會隨著鼠標的移動而變大變小,那么要計算放大塊左側距離原點和上側原點就要減去原圖距離屏幕的上邊高度和左邊高度。在一個水平位置和垂直位置中有我們可以挪動的區(qū)域,就是原圖片區(qū)域,鼠標挪動位置是一個塊狀位置,他的左側和上側距離瀏覽器上側和左側分別有一個長度,我們叫它們 ClientX 和 ClientY,而左上側鼠標沒有略過的位置實際上是一個點,我們拖動放大塊時,它會由一個點變成一個方塊,這個放大鏡左上邊的點所控制的這一點距離屏幕上側和左側的 ClientY 和 ClientX 會隨著鼠標的移動而變大變小,那么要計算放大塊左側距離原點和上側原點就要減去原圖距離屏幕的上邊高度和左邊高度。

計算方式

x = 事件對象.clientX - 外側盒子.offsetLeft;
Y = 事件對象.clientY - 外側盒子.offsetTop;

2.解決如何鼠標在黃塊內居中的問題,橫縱位移分別加上放大黃塊一半的長度和寬度。

計算方式

x = 事件對象.clientX - 外側盒子.offsetLeft - 小黃.offsetWidth/2;
Y = 事件對象.clientY - 外側盒子.offsetTop - 小黃.offsetHeight/2;
// 事件對象的 offsetX 和 offsetY
// 歸屬于事件對象
// 作用:關注的鼠標的坐標(鼠標相對于當前元素的坐標)
// 元素的 offsetLeft 和 offsetTop
// 歸屬于元素
// 作用:關注的元素的坐標(相對于offsetParent的坐標)

3. 小黃塊的最大距離

4.用preventDefault阻止事件冒泡

簡易實現代碼

<!DOCTYPE html>
<html>
<head lang="en">
 <meta charset="UTF-8">
 <title></title>
 <link rel="stylesheet" href="base.css" rel="external nofollow" />
</head>
<body>
 <div class="w">
 <div class="fdj">
 <!-- 左側 -->
 <div class="leftBox" id="_leftBox">
 <!-- 小圖 -->
 <img src="img/m.jpg" alt=""/>
 <!-- 小黃盒子 -->
 <div class="tool" id="_tool"></div>
 </div>
 <!-- 右側 -->
 <div class="rightBox" id="_rightBox">
 <img id="_bImg" src="img/b.jpg" alt=""/>
 </div>
 </div>
 </div>
 <!-- 引入的外部js程序文件 -->
 <script src="index.js"></script>
</body>
</html>
* {
 margin:0;
 padding:0;
}

.w {
 width: 1190px;
 margin: 0 auto;

}
.fdj {
 margin-top: 20px;
}

.fdj .leftBox {
 width: 400px;
 height: 400px;
 border: 1px solid #ccc;
 float: left;
 position: relative;
 overflow: hidden;
}

.fdj .tool {
 width: 250px;
 height: 250px;
 background:gold;
 opacity:.5;
 filter:alpha(opacity=50);
 position: absolute;
 top:0;
 left: 0;
 cursor: move;
 /* 默認隱藏 */
 display: none;

}
/* 給小黃加上active 就會顯示 */
.fdj .tool.active {
 display: block;
}

.fdj .rightBox {
 width: 500px;
 height: 500px;
 border:1px solid #ccc;
 float: left;
 overflow: hidden;
 /* 隱藏 */
 display: none;
 position: relative;
}
/* 加上active表示顯示 */
.fdj .rightBox.active {
 display: block;
}

.fdj .rightBox img {
 position: absolute;
}
//【準備:獲取要操作的元素】
var _leftBox = document.querySelector('#_leftBox'); // 左側盒子
var _tool = document.querySelector('#_tool'); // 小黃盒子
var _rightBox = document.querySelector('#_rightBox'); // 右側盒子
var _bImg = document.querySelector('#_bImg'); // 右側盒子中的大圖片


//【功能1:鼠標進入/離開左側盒子顯示/隱藏小黃和右側盒子】
// 1. 給_leftBox注冊鼠標進入事件 onmouseenter
_leftBox.onmouseenter = function () {
 // 1.1 顯示小黃盒子,給小黃盒子添加類名 active
 _tool.className = 'tool active';
 // 1.2 顯示右側盒子,給右側盒子添加類名 active 
 _rightBox.className = 'rightBox active';

}

// 2. 給_leftBox注冊鼠標離開事件 onmouseleave
_leftBox.onmouseleave = function () {
 // 2.1 顯示小黃盒子,給小黃盒子去除類名 active
 _tool.className = 'tool';
 // 2.2 顯示右側盒子,給右側盒子去除類名 active
 _rightBox.className = 'rightBox';
}

//【功能2:鼠標在左側區(qū)域移動時,控制小黃和右側盒子中圖片的位置】
// 1. 給左側盒子注冊鼠標移動事件 onmosuemove
_leftBox.onmousemove = function (e) {
 // 2. 通過事件對象獲取鼠標相對元素的位置(x,y)
 var x = e.clientX - _leftBox.offsetLeft- _tool.offsetWidth/2;
 var y = e.clientY - _leftBox.offsetTop - _tool.offsetHeight/2;

 // 這里給x和y賦值時,不要用事件對象的offsetX和offsetY。
 // 原因:因為【事件冒泡】,鼠標在移動時,有時會移動到小黃盒子上。若移動到小黃盒子上時,獲取的值不是相對于左側盒子元素,而是相對小黃盒子元素。所以當鼠標進入或離開小黃時,獲取的坐標值時大時小,導致小黃盒子上下左右波動。
 // 解決方案:在小黃移動事件中,停止冒泡。但是鼠標在移動時,就沒有效果了。
 // 最終解決方案:放棄使用事件對象offsetX/Y。 選擇事件對象的clienX/Y 結合左側盒子的位置計算出正確的位置。

 // 2.1 對x和y限制
 if (x < 0) {
 x = 0;
 }
 if (y < 0) {
 y = 0;
 }
 if (x > _leftBox.offsetWidth - _tool.offsetWidth) {
 x = _leftBox.offsetWidth - _tool.offsetWidth;
 }
 if (y > _leftBox.offsetHeight - _tool.offsetHeight) {
 y = _leftBox.offsetHeight - _tool.offsetHeight;
 }

 // 3. 把計算好的位置 賦值給小黃 
 _tool.style.left = x + 'px';
 _tool.style.top = y + 'px';

 // 4. 設定右側大圖片的位置(設置的方向是相反的,比例關系是1:2)
 _bImg.style.left = -2 * x + 'px';
 _bImg.style.top = -2 * y + 'px';
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • javascript實現簡單的貪吃蛇游戲

    javascript實現簡單的貪吃蛇游戲

    本文很簡單,給大家分享了一段使用javascript實現簡單的貪吃蛇游戲的代碼,算是對自己學習javascript的一次小小的總結,代碼參考了網友的部分內容,推薦給大家,希望對大家能夠有所幫助。
    2015-03-03
  • ES6 Iterator遍歷器原理,應用場景及相關常用知識拓展詳解

    ES6 Iterator遍歷器原理,應用場景及相關常用知識拓展詳解

    這篇文章主要介紹了ES6 Iterator遍歷器原理,應用場景及相關常用知識拓展,結合實例形式詳細分析了ES6 Iterator遍歷器具體原理、功能、用法、應用場景及知識拓展,需要的朋友可以參考下
    2020-02-02
  • 前端高頻面試題之JS中堆和棧的區(qū)別和瀏覽器的垃圾回收機制

    前端高頻面試題之JS中堆和棧的區(qū)別和瀏覽器的垃圾回收機制

    本文給大家分享前端高頻面試題JS中堆和棧的區(qū)別和瀏覽器的垃圾回收機制,本文分文別類給大家介紹了棧(stack)和堆(heap)的區(qū)別基本類型和引用類型的相關知識,瀏覽器垃圾回收機制包括基本概念給大家介紹的非常詳細,需要的朋友參考下吧
    2023-10-10
  • JavaScript實現的in_array函數

    JavaScript實現的in_array函數

    這篇文章主要介紹了JavaScript實現的in_array函數,用于判斷一個值是否在數組中,類似PHP的in_array函數,需要的朋友可以參考下
    2014-08-08
  • 淺析在javascript中創(chuàng)建對象的各種模式

    淺析在javascript中創(chuàng)建對象的各種模式

    下面小編就為大家?guī)硪黄獪\析在javascript中創(chuàng)建對象的各種模式。小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • JavaScript簡寫技巧總結

    JavaScript簡寫技巧總結

    這篇文章總結了JavaScript的一些簡寫技巧,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • ?javascript數組中的lastIndexOf方法

    ?javascript數組中的lastIndexOf方法

    這篇文章主要介紹了?javascript數組中的lastIndexOf方法,該方法可返回一個指定的字符串值最后出現的位置,在一個字符串中的指定位置從后向前搜索,下文詳細內容需要的小伙伴可以參考一下
    2022-03-03
  • JS實現textarea通過換行或者回車把多行數字分割成數組并且去掉數組中空的值

    JS實現textarea通過換行或者回車把多行數字分割成數組并且去掉數組中空的值

    這篇文章主要介紹了JS實現textarea通過換行或者回車把多行數字分割成數組并且去掉數組中空的值的相關資料,需要的朋友可以參考下
    2018-10-10
  • Layui數據表格 前后端json數據接收的方法

    Layui數據表格 前后端json數據接收的方法

    今天小編就為大家分享一篇Layui數據表格 前后端json數據接收的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 繪制微信小程序驗證碼功能的實例代碼

    繪制微信小程序驗證碼功能的實例代碼

    這篇文章主要介紹了繪制微信小程序驗證碼功能的實例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01

最新評論