js實(shí)現(xiàn)模態(tài)框拖拽
本文實(shí)例為大家分享了js實(shí)現(xiàn)模態(tài)框拖拽的具體代碼,供大家參考,具體內(nèi)容如下
效果展示和需求分析
效果展示

需求分析
- 點(diǎn)擊登錄后登錄表單和遮罩層顯示,點(diǎn)擊關(guān)閉按鈕隱藏。
- 輸入密碼時(shí)可以明文查看或者隱藏。
- 在表單的頭部按下鼠標(biāo)后可以拖拽表單。
- 鼠標(biāo)彈起拖拽結(jié)束。
代碼分析
HTML 代碼
<body> ? ? <a href="javascript:;" class="login">登錄我的賬號(hào)</a> ? ? <form action=""> ? ? ? ? <h4>賬號(hào)登錄</h4> ? ? ? ? <div class="login-items"> ? ? ? ? ?? ?<label for="uname">用戶名:</label > ? ? ? ? ?? ?<input type="text" placeholder="請(qǐng)輸入用戶名" id="uname"> ? ? ? ? ?? ?</div> ? ? ? ? <div class="login-items"> ? ? ? ? ? ? <label for="psw">登錄密碼:</label> ? ? ? ? ? ? <input type="password" name="" id="psw" placeholder="請(qǐng)輸入您的密碼"> ? ? ? ? ? ? <span class="close" id="eye-state"></span> ? ? ? ? </div> ? ? ? ? <a href="javascript:;" class="login-btn">登錄賬號(hào)</a > ? ? ? ? <a href="javascript:;" class="close-btn">關(guān)閉</a > ? ? </form> ? ? <div id="bg" class="login-bg"></div> </body> <script src="js/模態(tài)框.js"></script>
js 代碼
var eyeState = document.querySelector('#eye-state');
var pswInput = document.querySelector('#psw');
var login = document.querySelector('.login');
var loginBg = document.querySelector('#bg');
var loginForm = document.querySelector('form');
var closeBtn = document.querySelector('.close-btn');
?? ?
?? ?var eyeFlag = 0;
?? ?eyeState.onclick = setEye;
?? ?login.onclick = goLogin;
?? ?closeBtn.onclick = leaveLogin;
?? ?loginForm.children[0].addEventListener('mousedown', dragForm);
?? ?
?? ?// 表單內(nèi)容不可選,不然看著不舒服
?? ?loginForm.onselectstart = function(e) {
? ? ?? ?e.preventDefault();
?? ?}
?? ?
?? ?// 1、實(shí)現(xiàn)小眼睛改變密碼輸入狀態(tài)
?? ?function setEye() {
? ??? ??? ?if (!eyeFlag) {
? ? ? ? ?? ?eyeState.className = 'open';
? ? ? ? ?? ?pswInput.type = 'text';
? ? ? ? ?? ?eyeFlag = 1;
? ? ?? ?} else {
? ? ? ? ?? ?eyeState.className = 'close';
? ? ? ? ?? ?pswInput.type = 'password';
? ? ? ? ?? ?eyeFlag = 0;
? ? ?? ?}
?? ?}
?? ?
?? ?// 2、外面登錄按鈕實(shí)現(xiàn)表單、遮罩層的顯示和它自己隱藏
?? ?function goLogin() {
? ? ?? ?loginBg.style.visibility = 'visible';
? ? ?? ?loginForm.style.display = 'block';
? ? ?? ?this.style.display = 'none';
?? ?}
?? ?
?? ?// 3、關(guān)閉按鈕實(shí)現(xiàn)表單、遮罩層的隱藏和外面登錄按鈕的顯示
?? ?function leaveLogin() {
? ? ?? ?loginBg.style.visibility = 'hidden';
? ? ?? ?loginForm.style.display = 'none';
? ? ?? ?login.style.display = 'block';
?? ?}
?? ?
?? ?// 4、實(shí)現(xiàn)表單拖拽效果
?? ?function dragForm(e) {
?? ??? ?// 當(dāng)鼠標(biāo)在表單的標(biāo)題按下時(shí)獲取它在表單元素內(nèi)的坐標(biāo)并綁定移動(dòng)事件
? ? ?? ?var x = e.pageX - this.parentNode.offsetLeft;
? ? ?? ?var y = e.pageY - this.parentNode.offsetTop;
? ? ?? ?document.addEventListener('mousemove', move);
? ? ?? ?// 鼠標(biāo)彈起移除移動(dòng)事件
? ? ?? ?this.addEventListener('mouseup', function() {
? ? ? ? ?? ?document.removeEventListener('mousemove', move)
? ? ?? ?});
? ? ?? ?function move(event) {
? ? ? ? ?? ?loginForm.style.left = event.pageX - x + 'px';
? ? ? ? ?? ?loginForm.style.top = event.pageY - y + 'px';
? ? }
}分析
- 密碼輸入框,在點(diǎn)擊后面的眼睛即 span 元素時(shí)通過(guò) eyeFlag 變量來(lái)判斷設(shè)置表單的 type 屬性和 span 的類名(該用哪個(gè)小眼睛圖)。
- 鼠標(biāo)是在表單標(biāo)題區(qū)域按下后才有拖拽效果所以給標(biāo)題綁定 mousedown 事件。
- mousemove 和 mouseup 事件在鼠標(biāo)按下后分別綁定給 document 和 this(標(biāo)題)。
在實(shí)現(xiàn)拖拽時(shí)將 mousemove 事件綁定給標(biāo)題的話會(huì)出現(xiàn) bug 。快速拖拽時(shí)鼠標(biāo)會(huì)離開標(biāo)題導(dǎo)致表單沒(méi)有跟上。所以要將這個(gè)事件綁定給 document 。
表單跟隨鼠標(biāo)的原理:在鼠標(biāo)按下時(shí)根據(jù)鼠標(biāo)和表單在頁(yè)面的坐標(biāo)得到它在表單的坐標(biāo)(拖拽過(guò)程這個(gè)位置是不變的)。在鼠標(biāo)移動(dòng)過(guò)程根據(jù)鼠標(biāo)在頁(yè)面的動(dòng)態(tài)坐標(biāo)和它在表單的坐標(biāo)即可獲得表單在頁(yè)面的動(dòng)態(tài)坐標(biāo)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JS實(shí)現(xiàn)簡(jiǎn)單可拖動(dòng)的模態(tài)框
- JS實(shí)現(xiàn)模態(tài)框拖拽動(dòng)態(tài)效果
- JavaScript實(shí)現(xiàn)拖動(dòng)模態(tài)框
- JS實(shí)現(xiàn)簡(jiǎn)單拖動(dòng)模態(tài)框案例
- HTML+CSS+JavaScript實(shí)現(xiàn)可拖拽模態(tài)框
- js實(shí)現(xiàn)拖動(dòng)模態(tài)框效果
- JS實(shí)現(xiàn)拖動(dòng)模態(tài)框案例
- js實(shí)現(xiàn)模態(tài)框的拖拽效果
- js實(shí)現(xiàn)拖動(dòng)模態(tài)框
- JavaScript實(shí)現(xiàn)模態(tài)框拖拽效果
相關(guān)文章
微信小程序云開發(fā)實(shí)現(xiàn)云數(shù)據(jù)庫(kù)讀寫權(quán)限
這篇文章主要為大家詳細(xì)介紹了微信小程序云開發(fā)實(shí)現(xiàn)云數(shù)據(jù)庫(kù)讀寫權(quán)限,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05
PHP實(shí)現(xiàn)的各種中文編碼轉(zhuǎn)換類分享
這篇文章主要介紹了PHP實(shí)現(xiàn)的各種中文編碼轉(zhuǎn)換類分享,本文類庫(kù)支持簡(jiǎn)體中文、繁體中文、GB2312、BIG5、UTF-8等多種格式之間的轉(zhuǎn)換,需要的朋友可以參考下2015-01-01
詳解Webpack如何引入CDN鏈接來(lái)優(yōu)化編譯后的體積
這篇文章主要介紹了詳解Webpack如何引入CDN鏈接來(lái)優(yōu)化編譯后的體積,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
實(shí)現(xiàn)兩個(gè)文本框同時(shí)輸入的實(shí)例
下面小編就為大家?guī)?lái)一篇實(shí)現(xiàn)兩個(gè)文本框同時(shí)輸入的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09
淺談TypeScript3.7中值得注意的3個(gè)新特性
這篇文章主要介紹了TypeScript3.7中值得注意的3個(gè)新特性,對(duì)TS感興趣的同學(xué),可以參考下2021-05-05
js get和post請(qǐng)求實(shí)現(xiàn)代碼解析
這篇文章主要介紹了js get和post實(shí)現(xiàn)代碼解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02

