实现原理

1.onmousemove事件触发时不断更新鼠标的pageXY改变位置,
登陆框的偏移量=鼠标当前位置-鼠标到登录框边框的距离
2.onmousedown鼠标摁下时触发事件获取鼠标到登陆框的距离,再设置true允许拖拽
3.onmouseup 鼠标弹起设置false停止拖拽
4.登录框居中显示公式:(可视区域宽高-登录框宽高)/2
5.当浏览器窗口大小变化时触发事件window.onresize 再更新登陆框居中显示
代码中有详细的注释
完整代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>demo</title>
<style>
body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{margin:0;padding:0;}
body,button,input,select,textarea{font:12px/1.5 tahoma,arial,\5b8b\4f53;}
h1,h2,h3,h4,h5,h6{font-size:100%;}
address,cite,dfn,em,var{font-style:normal;}
code,kbd,pre,samp{font-family:courier new,courier,monospace;}
small{font-size:12px;}
ul,ol{list-style:none;}
a{text-decoration:none;}
a:hover{text-decoration:underline;}
sup{vertical-align:text-top;}
sub{vertical-align:text-bottom;}
legend{color:#000;}
fieldset,img{border:0;}
button,input,select,textarea{font-size:100%;}
table{border-collapse:collapse;border-spacing:0;}
.clear{clear: both;float: none;height: 0;overflow: hidden;}
/*p{font-size: 100px;}*/
#btn{width: 80px;
height: 40px;
background: #3b7ae3;
margin:0 auto;
display: block;
cursor: pointer;
border-style: none;
color: #fff;
font-size: 16px;}
#mask{
background: #000;
opacity: 0.75;
filter: alpha(opacity=75);
height: 1000px;
width: 100%;
position: absolute;
left: 0;
top: 0;
z-index: 1000;
}
#login{position: absolute; top: 100px; left: 100px; width: 400px; height: auto; border:1px solid #d5d5d5; z-index: 1001; }
.title{position: relative;background-color: #f7f7f7; cursor: move; height: 50px; line-height: 50px; font-size: 16px; color: #333; padding-left:30px;}
.close{position: absolute; top:0; right: 10px; color: #ccc;}
.content{background: #fff; padding: 15px 20px;}
.user{margin-bottom: 15px;}
.password{margin-bottom: 15px;}
.pt{display: block;
height: 38px;
padding-left: 15px;
border: 1px solid #ddd;
transition: .3s;
font-size: 14px;
color: #666;
width: 343px;
}
.sm{display: block;
height: 48px;
border: 1px solid #ddd;
transition: .3s;
font-size: 16px;
color: #666;
width: 360px;
background: #3b7ae3;
color: #fff;}
</style>
</head>
<body>
<!-- <div id="mask"></div> -->
<button id="btn" href="">登录</button>
<!-- <div class="login" id="login">
<div class="title" id="title">登录百度账号<a href="#" class="close">x</a></div>
<div class="content">
<div class="user"><input class="pt" type="input" value="手机/邮箱/用户名"></div>
<div class="password"><input class="pt" type="input" value="密码"></div>
<div class="submit"><input class="sm" type="submit" value="登录"></div>
</div>
</div> -->
<script type="text/javascript">
function b(){
//创建遮罩层div并插入body
var mask=document.createElement("div");
mask.id="mask";
mask.style.height=cheight+"px";
//宽度直接用100%在样式里
document.body.appendChild(mask);
//创建登录层div并插入body
var login=document.createElement("div");
login.id="login";
login.innerHTML='<div class="title" id="title">登录百度账号'+'<a href="#" class="close">x</a>'+'</div>'+
'<div class="content">'+'<div class="user">'+'<input class="pt" type="input" value="手机/邮箱/用户名">'+'</div>'+'<div class="password">'+'<input class="pt" type="input" value="密码">'+'</div>'+'<div class="submit">'+'<input class="sm" type="submit" value="登录">'+'</div>'+'</div>';
document.body.appendChild(login);
//窗口可视区域宽度
var cwidth= document.documentElement.clientWidth || document.body.clientWidth;
//窗口可视区域高度
var cheight= document.documentElement.clientHeight || document.body.clientHeight;
//登录框宽度
var lwidth=login.offsetWidth;
//登录框高度
var lheight=login.offsetHeight;
//设置登录框的居中显示
login.style.left=(cwidth-lwidth)/2+"px";
login.style.top=(cheight-lheight)/2+"px";
//设置遮罩层的高度
mask.style.height=cheight+"px";
//改变窗口大小后依然居中显示
window.onresize=function(){
if(document.compatMode=="CSS1Compat"){
cwidth=document.documentElement.clientWidth;
cheight=document.documentElement.clientHeight;
}else{
cwidth=document.body.clientWidth;
cheight=document.body.clientHeight;
}
login.style.left=(cwidth-lwidth)/2+"px";
login.style.top=(cheight-lheight)/2+"px";
mask.style.height=cheight+"px";
}
//获取拖拽容器
var title=document.getElementById("title");
var isDraging=false;
var mouseOffsetX;
var mouseOffsetY;
//鼠标按下事件
title.onmousedown=function(e){
var e=e||window.event;
/*var el=e.srcElement;
if(!el){
el=e.target;//兼容火狐
}*/
//鼠标相对于登录框的位置
mouseOffsetX=e.pageX-login.offsetLeft;
mouseOffsetY=e.pageY-login.offsetTop;
//鼠标摁下时为true
isDraging=true;
/*console.log(mouseOffsetY, mouseOffsetX)*/
}
//鼠标移动事件
document.onmousemove=function(e){
var e=e||window.event;
//鼠标移动时的坐标
var newMX=e.pageX;
var newMY=e.pageY;
//判断为true时可以拖拽
if(isDraging===true){
//登录框的偏移值=当前位置-鼠标到登录框的距离
var loginL=newMX-mouseOffsetX;
var loginT=newMY-mouseOffsetY;
//如果left top值超过边缘时就让他等于边缘
if(loginL<0){
loginL=0;
}else if(loginL>(cwidth-lwidth)){
loginL=cwidth-lwidth;
}
if(loginT<0){
loginT=0;
}else if(loginT>(cheight-lheight)){
loginT=cheight-lheight;
}
login.style.left=loginL+"px";
login.style.top=loginT+"px";
}
}
//鼠标弹起时设置为不可拖拽
document.onmouseup=function(){
isDraging=false;
}
//点击X关闭登录框和弹出层
var close=login.getElementsByClassName("close")[0];
close.onclick=function(){
document.body.removeChild(mask);
document.body.removeChild(login);
}
}
//点击登录弹出登录框和弹出层
window.onload=function(){
var btn=document.getElementById("btn");
btn.onclick=function(){
b();
}
}
</script>
</body>
</html>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# js
# 可拖动
# 登录框
# js实现拖动效果
# js实现点击弹窗弹出登录框
# JavaScript实现弹出式可拖动登录框
# 鼠标
# 拖拽
# 弹出
# 边缘
# 让他
# 中有
# 火狐
# 时就
# 按下
# 相对于
# 设置为
# 不断更新
# 偏移量
# button
# legend
# select
# fieldset
# px
# margin
# padding
相关文章:
建站之星logo尺寸如何设置最合适?
如何通过主机屋免费建站教程十分钟搭建网站?
如何通过智能用户系统一键生成高效建站方案?
建站VPS选购需注意哪些关键参数?
可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?
如何在景安云服务器上绑定域名并配置虚拟主机?
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
魔方云NAT建站如何实现端口转发?
如何在IIS中新建站点并配置端口与IP地址?
如何在建站宝盒中设置产品搜索功能?
专业网站建设制作报价,网页设计制作要考什么证?
平台云上自主建站:模板化设计与智能工具打造高效网站
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
网站制作需要会哪些技术,建立一个网站要花费多少?
高端网站建设与定制开发一站式解决方案 中企动力
高端建站三要素:定制模板、企业官网与响应式设计优化
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
香港服务器如何优化才能显著提升网站加载速度?
建站VPS配置与SEO优化指南:关键词排名提升策略
宝塔建站教程:一键部署配置流程与SEO优化实战指南
如何高效配置香港服务器实现快速建站?
如何基于云服务器快速搭建个人网站?
如何快速搭建安全的FTP站点?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
建设网站制作价格,怎样建立自己的公司网站?
如何选择CMS系统实现快速建站与SEO优化?
定制建站如何定义?其核心优势是什么?
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
如何零基础开发自助建站系统?完整教程解析
C#怎么使用委托和事件 C# delegate与event编程方法
h5在线制作网站电脑版下载,h5网页制作软件?
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
如何在橙子建站中快速调整背景颜色?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
文字头像制作网站推荐软件,醒图能自动配文字吗?
网站制作报价单模板图片,小松挖机官方网站报价?
如何用y主机助手快速搭建网站?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
PHP正则匹配日期和时间(时间戳转换)的实例代码
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
如何快速搭建高效简练网站?
建站之星伪静态规则如何设置?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
如何选择高性价比服务器搭建个人网站?
如何选择香港主机高效搭建外贸独立站?
,怎么用自己头像做动态表情包?
*请认真填写需求信息,我们会在24小时内与您取得联系。