使用原生JavaScript实现弹出层登录拖拽功能

在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">密&nbsp;&nbsp;码 
        <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>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值