• 原生js简单实现拖拽效果


    实现弹窗拖拽效果的原理是:按下鼠标并移动——拖拽移动物体,抬起鼠标——停止移动。主要触发三个事件:onmousedown、onmousemove以及onmouseup;

    首先搭建结构:一个宽350px、高200px的登录框

    <div id="login">
        <div id="box">登录窗</div>
    </div>
    <style>
            *{
                padding: 0;margin: 0;
            }
            #login{
                 350px;
                height: 200px;
                border: 1px solid #999;
                position: absolute;
                cursor: move;
                background-color: #fefefe;
            }
            #login #box{
                 350px;
                height: 30px;
                background-color: #eee;
                text-align: center;
                line-height: 30px;
            }
    </style>
    

    原生js代码实现:

    window.onload=function(){
                var login=document.getElementById('login');    //获取登录框ID
                login.onmousedown=function(e){       //鼠标按下登录框区域时触发
                    var e=e||window.event;      //兼容ie和firefox
                    var diffX=e.clientX-login.offsetLeft;   //鼠标坐标值-登录框到左端的距离=鼠标到弹框左边的距离,下边同理
                    var diffY=e.clientY-login.offsetTop;    
                    if(diffX>0&&diffY>0){
                        document.onmousemove=function(e){     //触发鼠标移动事件
                            login.style.left=e.clientX-diffX+'px';    //不断移动过程中,鼠标坐标值-鼠标到弹框左边的距离即登录框到页面的左边距离不断更新,实现拖拽效果
                            login.style.top=e.clientY-diffY+'px';
    
                            var cw=document.documentElement.clientWidth||document.body.clientWidth;   //兼容ie和firefox,获取网页可视区域宽、高
                            var ch=document.documentElement.clientHeight||document.body.clientHeight;
                            if(e.clientX-diffX<0){   //看下图3情形,判断已出左边界
                                login.style.left='0px';   //出界都重置为0px
                            }else if(e.clientX-diffX>cw-login.offsetWidth){   //看下图2情形,判断已出右边界
                                login.style.left=cw-login.offsetWidth+'px';   //重置为左边最大值
                            }
                            if(e.clientY-diffY<0){   //与上同理
                                login.style.top='0px';
                            }else if(e.clientY>ch-login.offsetHeight){
                                login.style.top=ch-login.offsetHeight+'px';
                            }
                        }
                    }    
                    document.onmouseup=function(){    //鼠标抬起时,鼠标按下与移动事件为null
                        document.onmousemove=null;
                        document.onmouseup=null;
                    }
                }
            }
    

    如果有什么优化的方式也请多指教。

  • 相关阅读:
    Linux命令发送Http的get或post请求(curl和wget两种方法)
    大数据面试题以及答案整理(一)
    大数据面试题及答案-汇总版
    Linux shell之打印输出
    Java开发中常见的危险信号(上)
    sencha touch笔记(5)——DataView组件(1)
    sencha touch(7)——list组件
    sencha touch笔记(6)——路由控制(1)
    [置顶] Android源码分析-点击事件派发机制
    UVa 10330 Power Transmission / 最大流
  • 原文地址:https://www.cnblogs.com/heyujun-/p/6696669.html
Copyright © 2020-2023  润新知