时间:2021-05-25
在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="images/logo.gif" alt="" /></div> <div class="member">个人中心 <ul class="list"> <li><a href="###">设置</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">密 码 <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>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JS弹出可拖拽可关闭的div层完整实现方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下:JS弹出可拖拽可关闭的div层html,bo
其实对于弹出层而言,拖拽最初的目的很单纯,就是为了通过拉开层,使被弹出层挡住的内容可见,(当然,后来关于拖拽的功能不断被优化,使得拖拽的应用有了别的意义,最典型
弹出层效果是一个很实用的功能,很多网站都采用了这种方式实现登录和注册,比如百度:弹出层的特点:点击登录或注册的时候在页面的中间部分弹出一个登录或注册区域并且页面
整理文档,搜刮出一个vuejs2.0运用原生js实现简单的拖拽元素功能示例,留作笔记。.select-item{background-color:#5bc0de
本文实例讲述了JS实现网页Div层Clone拖拽效果。分享给大家供大家参考。具体如下:这是一个层拖动,网页上的拖拽Clone效果实例,两个层可在鼠标的拖动下,任