高清放大鏡案例

<style>
    * {
      margin: 0;
      padding: 0;
    }

    .box {
      width: 350px;
      height: 350px;
      margin: 100px;
      border: 1px solid #ccc;
      position: relative;
    }

    .big {
      width: 400px;
      height: 400px;
      position: absolute;
      top: 0;
      left: 360px;
      border: 1px solid #ccc;
      overflow: hidden;
      display: none;
    }

    .mask {
      width: 175px;
      height: 175px;
      background: rgba(255, 255, 0, 0.4);
      position: absolute;
      top: 0px;
      left: 0px;
      cursor: move;
      display: none;
    }

    .small {
      position: relative;
    }
  </style>
</head>
<body>
<div class="box" id="box">
  <div class="small"><!--小層-->
    <img src="images/small.png" width="350" alt=""/>
    <div class="mask"></div><!--遮擋層-->
  </div><!--小圖-->
  <div class="big"><!--大層-->
    <img src="images/big.jpg" width="800" alt=""/><!--大圖-->
  </div><!--大圖-->
</div>
 //獲取需要的元素
  var box = my$("box");
  //獲取小圖的div
  var small = box.children[0];
  //遮擋層
  var mask = small.children[1];
  //獲取大圖的div
  var big = box.children[1];
  //獲取大圖
  var bigImg = big.children[0];

  //鼠標進入顯示遮擋層和大圖的div
  box.onmouseover = function () {
    mask.style.display = "block";
    big.style.display = "block";
  };
  //鼠標離開隱藏遮擋層和大圖的div
  box.onmouseout = function () {
    mask.style.display = "none";
    big.style.display = "none";
  };

  //鼠標的移動事件---鼠標是在小層上移動
  small.onmousemove = function (e) {
    //鼠標此時的可視區(qū)域的橫坐標和縱坐標
    //主要是設(shè)置鼠標在遮擋層的中間顯示
    var x = e.clientX - mask.offsetWidth / 2;
    var y = e.clientY - mask.offsetHeight / 2;
    //主要是margin的100px的問題
    x = x - 100;
    y = y - 100;
    //橫坐標的最小值
    x = x < 0 ? 0 : x;
    //縱坐標的最小值
    y = y < 0 ? 0 : y;
    //橫坐標的最大值
    x = x > small.offsetWidth - mask.offsetWidth ? small.offsetWidth - mask.offsetWidth : x;
    //縱坐標的最大值
    y = y > small.offsetHeight - mask.offsetHeight ? small.offsetHeight - mask.offsetHeight : y;
    //為遮擋層的left和top賦值
    mask.style.left = x + "px";
    mask.style.top = y + "px";

    //遮擋層的移動距離/大圖的移動距離=遮擋層的最大移動距離/大圖的最大移動距離
    //大圖的移動距離=遮擋層的移動距離*大圖的最大移動距離/遮擋層的最大移動距離

    //大圖的橫向的最大移動距離
    var maxX = bigImg.offsetWidth - big.offsetWidth;

    //大圖的縱向的最大移動距離
    //var maxY = bigImg.offsetHeight - big.offsetHeight;

    //大圖的橫向移動的坐標
    var bigImgMoveX = x * maxX / (small.offsetWidth - mask.offsetWidth);
    //大圖的縱向移動的坐標
    var bigImgMoveY = y * maxX / (small.offsetWidth - mask.offsetWidth);

    //設(shè)置圖片移動
    bigImg.style.marginLeft = -bigImgMoveX + "px";
    bigImg.style.marginTop = -bigImgMoveY + "px";

  };

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子宠页,更是在濱河造成了極大的恐慌,老刑警劉巖担钮,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異尤仍,居然都是意外死亡箫津,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進店門宰啦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來苏遥,“玉大人,你說我怎么就攤上這事赡模√锾浚” “怎么了?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵漓柑,是天一觀的道長教硫。 經(jīng)常有香客問我,道長欺缘,這世上最難降的妖魔是什么栋豫? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任挤安,我火速辦了婚禮谚殊,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蛤铜。我一直安慰自己嫩絮,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布围肥。 她就那樣靜靜地躺著剿干,像睡著了一般。 火紅的嫁衣襯著肌膚如雪穆刻。 梳的紋絲不亂的頭發(fā)上置尔,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天,我揣著相機與錄音氢伟,去河邊找鬼榜轿。 笑死幽歼,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的谬盐。 我是一名探鬼主播甸私,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼飞傀!你這毒婦竟也來了皇型?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤砸烦,失蹤者是張志新(化名)和其女友劉穎弃鸦,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體外冀,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡寡键,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了雪隧。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片西轩。...
    茶點故事閱讀 39,703評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖脑沿,靈堂內(nèi)的尸體忽然破棺而出藕畔,到底是詐尸還是另有隱情,我是刑警寧澤庄拇,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布注服,位于F島的核電站,受9級特大地震影響措近,放射性物質(zhì)發(fā)生泄漏溶弟。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一瞭郑、第九天 我趴在偏房一處隱蔽的房頂上張望辜御。 院中可真熱鬧,春花似錦屈张、人聲如沸擒权。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽碳抄。三九已至,卻和暖如春场绿,著一層夾襖步出監(jiān)牢的瞬間剖效,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留璧尸,地道東北人劝贸。 一個月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像逗宁,于是被迫代替她去往敵國和親映九。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內(nèi)容