欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生js實(shí)現(xiàn)彈出層登錄拖拽功能

 更新時間:2016年12月05日 17:25:59   作者:KoalaShane  
這篇文章主要為大家詳細(xì)介紹了使用原生JavaScript實(shí)現(xiàn)彈出層登錄拖拽功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下

在WEB開發(fā)過程中,總會遇到一些從未接觸過的需求,總是想盡一切辦法去研究,最終實(shí)現(xiàn)效果,在實(shí)現(xiàn)效果的那一刻成就感爆棚,有木有?

留言墻、彈出框等一些常見地方都有拖拽功能,方便用戶體驗嘛。

實(shí)現(xiàn)拖拽功能 ,三個事件 mousemove , mouseup ,mousedown, 偏移量(offsetLeft, offsetTop , offsetWidth ,offsetHeight),窗口坐標(biāo)位置(clientX ,clientY ) 以及獲取可視區(qū)域方法的兼容性處理。

之前做的比較多的留言墻效果時寫過的,這當(dāng)時做的筆記,現(xiàn)在來整理整理。

JavaScript代碼:

window.onload = function() {
 var btn = document.getElementsByClassName('login')[0]
 var close = document.getElementById('close');
 var login = document.getElementById('login');
 var top = (document.documentElement.clientHeight - 250) / 2; //top值等于(獲取頁面可視區(qū)域的寬度 - 登錄框的高度) / 2
 var left = (document.documentElement.clientWidth - 350) / 2;
 var open = document.getElementById('screen');
 btn.onclick = function() {
  login.style.display = 'block';
  login.style.left = left + 'px';
  login.style.top = top + 'px';
  open.style.display = 'block';
  open.style.width = getInner().width + 'px'; //彈出層的寬度等于可視窗口的寬度
  open.style.height = getInner().height + 'px';
 }
 close.onclick = function() {
  login.style.display = 'none';
  open.style.display = 'none';
 }
 window.onresize = function() {
   var top = (getInner().height - 250) / 2;
   var left = (getInner().width - 350) / 2;
   login.style.left = left + 'px';
   login.style.top = top + 'px';
  }
  //跨瀏覽器獲取可視窗口
 function getInner() {
  if (window.innerWidth != 'undefined') { //IE 不支持返回undefind
   return {
    width: window.innerWidth,
    height: window.innerHeight
   }
  } else {
   return {
    width: document.documentElement.clientWidth,
    height: document.documentElement.clientHeight
   }
  }
 }
 //實(shí)現(xiàn)拖拽功能 ,三個事件 mousemove , mouseup ,mousedown
 //clientX ,clientY 時鼠標(biāo)指針相對于整個屏幕的坐標(biāo)距離
 //offsetLeft, offsetTop 獲取當(dāng)前元素相對于父元素的位置,在這里,父元素是document
 login.onmousedown = function(e) {
   stop(e); //阻止事件默認(rèn)行為
   var e = e || window.event;
   var oLeft = e.clientX - login.offsetLeft; //login.offsetLeft 獲取盒子邊框到瀏覽器左邊框的距離
   var otop = e.clientY - login.offsetTop;
   document.onmousemove = function(e) { //移動的是整體的doucment
    var e = e || window.event;
    //不能移出可視區(qū)域
    var left = e.clientX - oLeft;
    var top = e.clientY - otop;
    //左右
    if (left < 0) { //如果盒子距左邊的距離小于零,即超出
     left = 0;
    } else if (left > getInner().width - login.offsetWidth) { //可視區(qū)域的長度,減去盒子的長度 offsetWidth
     left = getInner().width - login.offsetWidth;
    }
    //上下
    if (top < 0) {
     top = 0;
    } else if (top > getInner().height - login.offsetHeight) {
     top = getInner().height - login.offsetHeight;
    }
    login.style.left = left + 'px';
    login.style.top = top + 'px';
   }
   document.onmouseup = function() {
    document.onmousemove = null;
    document.onmouseup = null;
   }
  }
  //取消默認(rèn)行為
 function stop(e) {
  var e = e || window.event;
  if (typeof e.preventDefault != 'undefined') {
   e.preventDefault(); //W3C
  } else {
   e.returnValue = false; //IE阻止事件默認(rèn)行為
  }
 }
}

HTML代碼:

<div id="header">
 <div class="logo"><img src="images/logo.gif" alt="" /></div>
 <div class="member">個人中心
  <ul class="list">
   <li><a href="###">設(shè)置</a></li>
   <li><a href="###">換膚</a></li>
   <li><a href="###">幫助</a></li>
   <li><a href="###">退出</a></li>
  </ul>
 </div>
 <div class="login">登錄</div>
</div>

<div id="login">
 <h2><img src="images/close.png" alt="" class="close" id="close" />登錄</h2>
 <div class="user">用戶名<input type="text" name="user" class="text" /></div>
 <div class="pass">密&nbsp;&nbsp;碼 
  <input type="password" name="pass" class="text" /></div>
 <div class="button">
  <input type="button" class="submit" value="" /></div>
 <div class="other">注冊新用戶 | 忘記密碼</div>
</div>
<div id="screen"></div>
<script type="text/javascript" src="demo.js"></script>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript中的class類詳解

    JavaScript中的class類詳解

    JavaScript?中的類(Class)是一種新的語言特性,它讓我們可以使用面向?qū)ο缶幊痰乃枷雭砀臃奖愕亟M織和管理代碼。在本文中,我們將詳細(xì)介紹?JavaScript?中的類特性,感興趣的同學(xué)可以借鑒閱讀
    2023-05-05
  • 使用js獲取QueryString的方法小結(jié)

    使用js獲取QueryString的方法小結(jié)

    從網(wǎng)上看到一些使用js獲取QueryString的方法,但用起來不是很理想,所以決定自己寫一個。主要原理是使用正則表達(dá)式匹配location.search中的字符串。
    2010-02-02
  • D3.js實(shí)現(xiàn)散點(diǎn)圖和氣泡圖的方法詳解

    D3.js實(shí)現(xiàn)散點(diǎn)圖和氣泡圖的方法詳解

    這篇文章將會給大家介紹了另外兩種可視化圖表,利用D3.js實(shí)現(xiàn)散點(diǎn)圖和氣泡圖,文章通過多個方面介紹的非常詳細(xì),下面來一起看看吧。
    2016-09-09
  • BootStrap 動態(tài)添加驗證項和取消驗證項的實(shí)現(xiàn)方法

    BootStrap 動態(tài)添加驗證項和取消驗證項的實(shí)現(xiàn)方法

    這篇文章主要介紹了BootStrap 動態(tài)添加驗證項和取消驗證項的實(shí)現(xiàn)方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • JavaScript仿小米輪播圖效果

    JavaScript仿小米輪播圖效果

    這篇文章主要為大家詳細(xì)介紹了JavaScript仿小米輪播圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • js 去掉字符串前后空格實(shí)現(xiàn)代碼集合

    js 去掉字符串前后空格實(shí)現(xiàn)代碼集合

    這篇文章主要介紹了js 去掉字符串前后空格實(shí)現(xiàn)代碼集合,需要的朋友可以參考下
    2017-03-03
  • bootstrap響應(yīng)式工具使用詳解

    bootstrap響應(yīng)式工具使用詳解

    這篇文章主要介紹了bootstrap響應(yīng)式工具使用的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 一文教你如何優(yōu)雅的使用WebSocket

    一文教你如何優(yōu)雅的使用WebSocket

    WebSocket最大特點(diǎn)就是服務(wù)器可以主動向客戶端推送信息,客戶端也可以主動向服務(wù)器發(fā)送信息,是真正的雙向平等對話,屬于服務(wù)器推送技術(shù)的一種,下面這篇文章主要給大家介紹了關(guān)于如何優(yōu)雅的使用WebSocket的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • 給easyui datebox擴(kuò)展一個清空的實(shí)例

    給easyui datebox擴(kuò)展一個清空的實(shí)例

    下面小編就為大家?guī)硪黄oeasyui datebox擴(kuò)展一個清空按鈕的實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • javascript實(shí)現(xiàn)網(wǎng)頁背景煙花效果的方法

    javascript實(shí)現(xiàn)網(wǎng)頁背景煙花效果的方法

    這篇文章主要介紹了javascript實(shí)現(xiàn)網(wǎng)頁背景煙花效果的方法,涉及javascript數(shù)學(xué)運(yùn)算及頁面元素動態(tài)操作的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08

最新評論