学习来源:https://www.bilibili.com/video/BV1HJ41147DG
要求
弹出框,我们也称为模态框。
1.点击弹出层,会弹出模态框, 并且显示灰色半透明的遮挡层。
2.点击关闭按钮,可以关闭模态框,并且同时关闭灰色半透明遮挡层。
3.鼠标放到模态框最上面一行,可以按住鼠标拖拽模态框在页面中移动
4.鼠标松开,可以停止拖动模态框移动
思路
- 点击弹出层, 模态框和遮挡层就会显示出来 display:block;
- 点击关闭按钮,模态框和遮挡层就会隐藏起来 display:none;
- 在页面中拖拽的原理:鼠标按下并且移动, 之后松开鼠标
- 触发事件是鼠标按下 mousedown、鼠标移动 mousemove、鼠标松开 mouseup
- 拖拽过程:鼠标移动过程中,获得最新的值赋值给模态框的 left 和 top 值,这样模态框可以跟着鼠标走了
- 鼠标按下触发的事件源是最上面一行,就是 id 为 login-title
- 鼠标的坐标减去鼠标在盒子内的坐标,才是模态框真正的位置。
- 鼠标按下,我们要得到鼠标在盒子的坐标。
- 鼠标移动,就让模态框的坐标设置为:鼠标坐标减去盒子坐标即可,注意移动事件写到按下事件里面。
- 鼠标松开就停止拖拽,就是可以让鼠标移动事件解除
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
* {
/* 清除内边距、外边距 */
margin: 0;
padding: 0;
/* 盒子大小为 width,padding 和 border 不会撑大盒子 */
box-sizing: border-box;
}
a {
text-decoration: none;
color: #000;
}
/* 清除li的列表样式 */
li {
list-style: none;
}
button,
input {
/* 去掉默认的灰色边框 */
border: 0;
/* 去掉默认的获得焦点后的蓝色边框 */
outline: none;
}
button {
cursor: pointer;
background-color: transparent;
}
.login-header {
width: 100%;
margin-top: 5px;
text-align: center;
font-size: 24px;
line-height: 30px;
}
.login {
display: none;
position: fixed;
width: 514px;
height: 290px;
left: 50%;
top: 50%;
margin-top: -145px;
padding-top: 20px;
border: #ebebeb solid 1px;
background-color: #fff;
text-align: center;
box-shadow: 0px 0px 20px #ddd;
z-index: 9999;
transform: translate(-50%, -50%);
}
.login label {
display: inline-block;
width: 70px;
line-height: 40px;
margin-right: 10px;
font-size: 14px;
text-align: right;
}
.login-title {
font-size: 18px;
margin-bottom: 30px;
cursor: move;
}
.login-title span {
position: absolute;
right: -20px;
top: -20px;
width: 45px;
line-height: 45px;
font-size: 14px;
background: #ffffff;
border: #ebebeb solid 1px;
border-radius: 50%;
transition: border-color .2s;
cursor: pointer;
}
.login-input {
width: 352px;
line-height: 40px;
text-indent: 5px;
margin-bottom: 20px;
border: #ebebeb 1px solid;
transition: border-color .2s;
}
.btn {
width: 50%;
margin: 10px auto 0px auto;
line-height: 43px;
font-size: 14px;
border: #ebebeb 1px solid;
text-align: center;
transition: border-color .2s;
}
.btn:hover,
.login-title span:hover,
.login-input:hover {
border-color: skyblue;
}
.login-bg {
display: none;
position: fixed;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
background: rgba(0, 0, 0, .3);
}
</style>
</head>
<body>
<div class="login-header"><a id="link" href="javascript:;">点击,弹出登录框</a></div>
<div class="login">
<form action="">
<ul>
<li class="login-title">
登录会员
<span>
<a id="closeBtn" href="javascript:void(0);" class="close-login">
关闭
</a>
</span>
</li>
<li class="login-uname">
<label>用户名:</label><input type="text" placeholder="请输入用户名" class="login-input">
</li>
<li class="login-pwd">
<label>登录密码:</label><input type="password" placeholder="请输入登录密码" class="login-input">
</li>
<li class="login-btn">
<button class="btn">登录会员</button>
</li>
</ul>
</form>
</div>
<!-- 遮盖层 -->
<div class="login-bg"></div>
<script>
// 获取元素
var link = document.querySelector('#link');
var loginTitle = document.querySelector('.login-title');
var closeBtn = document.querySelector('#closeBtn');
var login = document.querySelector('.login');
var loginBg = document.querySelector('.login-bg');
// 点击弹出层这个链接——#link,让遮盖层和 login 显示出来
link.addEventListener('click', function () {
login.style.display = 'block';
loginBg.style.display = 'block';
})
// 点击 closeBtn 就隐藏遮盖层和 login
closeBtn.addEventListener('click', function () {
login.style.display = 'none';
loginBg.style.display = 'none';
})
// 拖拽
// 鼠标按下, 就获得鼠标在盒子内的坐标
loginTitle.addEventListener('mousedown', function (e) {
var mouseX = e.pageX - login.offsetLeft;
var mouseY = e.pageY - login.offsetTop;
// 鼠标移动的时候,把鼠标在页面中的坐标减去鼠标在盒子内的坐标就是模态框的left和top值
document.addEventListener('mousemove', move);
function move(e) {
login.style.left = e.pageX - mouseX + 'px';
login.style.top = e.pageY - mouseY + 145 + 'px';
}
// 因为取消事件需要标识符,所以 mousemove 事件使用了 函数名 方式,而不是直接写函数方式
// document.addEventListener('mousemove',function(e) {
// login.style.left = e.pageX - mouseX + 'px';
// login.style.top = e.pageY - mouseY + 145 + 'px';
// })
// 鼠标弹起,就让鼠标移动事件移除
document.addEventListener('mouseup', function () {
document.removeEventListener('mousemove', move);
})
})
</script>
</body>
</html>