在WEB开发过程中,总会遇到一些从未接触过的需求,总是想尽一切办法去研究,最终实现效果,在实现效果的那一刻成就感爆棚,有木有?
留言墙、弹出框等一些常见地方都有拖拽功能,方便用户体验嘛。
实现拖拽功能 ,三个事件 mousemove , mouseup ,mousedown, 偏移量(offsetLeft, offsetTop , offsetWidth ,offsetHeight),窗口坐标位置(clientX ,clientY ) 以及获取可视区域方法的兼容性处理。
之前做的比较多的留言墙效果时写过的,这当时做的笔记,现在来整理整理。
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值等于(获取页面可视区域的宽度 - 登录框的高度) / 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 } } } //实现拖拽功能 ,三个事件 mousemove , mouseup ,mousedown //clientX ,clientY 时鼠标指针相对于整个屏幕的坐标距离 //offsetLeft, offsetTop 获取当前元素相对于父元素的位置,在这里,父元素是document login.onmousedown = function(e) { stop(e); //阻止事件默认行为 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; //不能移出可视区域 var left = e.clientX - oLeft; var top = e.clientY - otop; //左右 if (left < 0) { //如果盒子距左边的距离小于零,即超出 left = 0; } else if (left > getInner().width - login.offsetWidth) { //可视区域的长度,减去盒子的长度 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; } } //取消默认行为 function stop(e) { var e = e || window.event; if (typeof e.preventDefault != 'undefined') { e.preventDefault(); //W3C } else { e.returnValue = false; //IE阻止事件默认行为 } } }
HTML代码:
<div id="header"> <div class="logo"><img src="/UploadFiles/2021-04-02/logo.gif">以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“原生js实现弹出层登录拖拽功能”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新动态
2024年11月14日
2024年11月14日
- 魔兽世界wlk暗牧一键输出宏是什么 wlk暗牧一键输出宏介绍
- 群星.1996-红不让台语原唱2辑【福和唱片】【WAV+CUE】
- 郭书瑶.2009-爱的抱抱(EP)【种子音乐】【FLAC分轨】
- 郑瑞芬.1989-BE.MY.BABY【现代】【WAV+CUE】
- 花钱请人每周放30万只不咬人的蚊子 防治登革热传播
- 饭制《第一后裔》丧尸版弗蕾娜
- 贝克汉姆亲临!2024FC品类游戏嘉年华圆满落幕
- 「命轨爻错之翼」风之翼发放说明
- 《原神》前瞻特别节目回顾长图
- 米游币抽抽乐-原神专场现已开启!
- 黑鸭子2001《风情中国HQCD》[日本版][WAV+CUE]
- 陈杰洲1990-成人礼[滚石][WAV+CUE]
- MarkAanderud-HandsFree(2024)[24-44,1]FLAC
- 孙露《观心》1:1母盘直刻限量版[低速原抓WAV+CUE][361M]
- 钟志刚《汽车DJ玩主》[低速原抓WAV+CUE][1G]