美文网首页
JavaScrip--事件应用

JavaScrip--事件应用

作者: 卓小生 | 来源:发表于2016-12-14 15:24 被阅读0次

事件应用

拖拽

拖拽原理

三大事件
+ onmousedown : 选择元素
+ onmousemove : 移动元素
+ onmouseup   : 释放元素
<style>
div{
    height: 100px;
    width: 100px;
    background: yellowgreen;
    position: absolute;
}
</style>
<div id="div1"></div>
var oDiv = document.getElementById('div1');

oDiv.onmousedown = function(){
    oDiv.onmousemove = function(){//鼠标移动事件是在鼠标按下事件之后

    }

    oDiv.onmouseup = function (){//鼠标抬起之后要清除鼠标按下事件
        oDiv.onmousemove= null;
        oDiv.onmouseup = null;
    }
}

- 鼠标和Div的相对距离不变

var oDiv = document.getElementById('div1');

oDiv.onmousedown = function(ev){
    var ev = ev || window.event;

    //鼠标和Div的相对距离 
    var disX = ev.clientX - oDiv.offsetLeft;
    var disY = ev.clientY - oDiv.offsetTop;

    oDiv.onmousemove = function(ev){
        var ev = ev || window.event;
        oDiv.style.left = ev.clientX - disX + 'px';
        oDiv.style.top = ev.clientY - disY + 'px';
    }

    oDiv.onmouseup = function (){
        oDiv.onmousemove= null;
        oDiv.onmouseup = null;
    }
}
把拖拽加到document上

如果拖得太快, 会移出div, 可以把onmousemove事件加在document上

注意:移出事件也是在doucment

var oDiv = document.getElementById('div1');

oDiv.onmousedown = function(ev){
    var ev = ev || window.event;
    var disX = ev.clientX - oDiv.offsetLeft;
    var disY = ev.clientY - oDiv.offsetTop;
    document.onmousemove = function(ev){
        var ev = ev || window.event;
        oDiv.style.left = ev.clientX - disX + 'px';
        oDiv.style.top = ev.clientY - disY + 'px';
    }

    oDiv.onmouseup = function (){
        document.onmousemove= null;
        oDiv.onmouseup = null;
    }
}
拖拽的问题

如果拖拽文字或者图片, 由于浏览器的默认行为, 不能正常的拖拽

解决办法: 阻止浏览器默认行为

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
<style>
img{;
    position: absolute;
}
</style>
</head>
<body>
    <img src="img/1.jpg" alt="">
<script>
var oImg = document.getElementsByTagName('img')[0];


oImg.style.position = 'absolute';
oImg.onmousedown = function(ev){
    var ev = ev || window.event;
    var disX = ev.clientX - oImg.offsetLeft;
    var disY = ev.clientY - oImg.offsetTop;
    document.onmousemove = function(ev){
        var ev = ev || window.event;
        oImg.style.left = ev.clientX - disX + 'px';
        oImg.style.top = ev.clientY - disY + 'px';
        return false;//阻止浏览器默认行为

    }

    oImg.onmouseup = function (){
        document.onmousemove= null;
        oImg.onmouseup = null;
    }
    return false;//阻止浏览器默认行为
}
</script>
</body>
</html>

拖拽的封装

两个步骤:

  1. 将拖拽代码全部放进drag函数中
  2. 把需要变化的变量改成参数
function drag(obj){
    obj.onmousedown = function(ev){
        var ev = ev || window.event;
        var disX = ev.clientX - obj.offsetLeft;
        var disY = ev.clientY - obj.offsetTop;
        document.onmousemove = function(ev){
            var ev = ev || window.event;
            obj.style.left = ev.clientX - disX + 'px';
            obj.style.top = ev.clientY - disY + 'px';
            return false;

        }

        obj.onmouseup = function (){
            document.onmousemove= null;
            obj.onmouseup = null;
        }
        return false;
    }

}
限制拖拽的范围

在窗口内拖动

function drag(obj){
    obj.onmousedown = function(ev){
        var ev = ev || window.event;


        var disX = ev.clientX - obj.offsetLeft;
        var disY = ev.clientY - obj.offsetTop;
        document.onmousemove = function(ev){
            var ev = ev || window.event;


            var left  = ev.clientX - disX;
            var top = ev.clientY - disY;
            if(left<0){
                left=0;
            }
            else if(left>document.documentElement.clientWidth-obj.offsetWidth){
                left = document.documentElement.clientWidth-obj.offsetWidth;
            }
            if(top<0){
                top=0;
            }
            else if(top>document.documentElement.clientHeight-obj.offsetHeight){
                top = document.documentElement.clientHeight-obj.offsetHeight;
            }

            obj.style.left =  left + 'px';
            obj.style.top = top + 'px';
            return false;

        }

        obj.onmouseup = function (){
            document.onmousemove= null;
            obj.onmouseup = null;
        }
        return false;
    }

}
磁性吸附效果

比如说以前的一些音乐播放器, 播放列表和歌词是两个分开的面板, 可以分开可以合并
合并的时候不需要精确的拖拽,而是拖拽到两个面板距离很近时自动合并

function drag(obj){
    obj.onmousedown = function(ev){
        var ev = ev || window.event;


        var disX = ev.clientX - obj.offsetLeft;
        var disY = ev.clientY - obj.offsetTop;
        document.onmousemove = function(ev){
            var ev = ev || window.event;


            var left  = ev.clientX - disX;
            var top = ev.clientY - disY;
            if(left<100){//距离可视区域范围的四边小于50px,则元素将直接吸附对应的边上
                left=0;
            }
            else if(left>document.documentElement.clientWidth-obj.offsetWidth){
                left = document.documentElement.clientWidth-obj.offsetWidth;
            }
            if(top<0){
                top=0;
            }
            else if(top>document.documentElement.clientHeight-obj.offsetHeight){
                top = document.documentElement.clientHeight-obj.offsetHeight;
            }

            obj.style.left =  left + 'px';
            obj.style.top = top + 'px';
            return false;

        }

        obj.onmouseup = function (){
            document.onmousemove= null;
            obj.onmouseup = null;
        }
        return false;
    }

}

碰撞检测

js中我们使用的是判断两个物体位置是否重合来判断两个物体是否发生了碰撞

常用的方法是使用九宫格法

碰撞检测.png

拖动div, 如果检测到碰撞, 则改变图片

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
<style>
div{
    height: 100px;
    width: 100px;
    background: yellowgreen;
    position: absolute;

}

img{
    position: absolute;
    top: 300px;
    left: 500px;
}


</style>
</head>
<body>
    <div id="div1"></div>
    <img src="img/1.jpg" alt="">
<script>
function preventDefault(e) {
    if (e.preventDefault)
        e.preventDefault();
    else
        e.returnValue = false;
}

function addEvent(node, type, handler) {
    if (!node) return false;
    if (node.addEventListener) {
        node.addEventListener(type, handler, false);
        return true;
    }
    else if (node.attachEvent) {
        node['e' + type + handler] = handler;
        node[type + handler] = function() {
            node['e' + type + handler](window.event);
        };
        node.attachEvent('on' + type, node[type + handler]);
        return true;
    }
    return false;
}


function removeEvent(node, type, handler) {
    if (!node) return false;
    if (node.removeEventListener) {
        node.removeEventListener(type, handler, false);
        return true;
    }
    else if (node.detachEvent) {
        node.detachEvent('on' + type, node[type + handler]);
        node[type + handler] = null;
    }
    return false;
}

function drag(obj){



    addEvent(obj, 'mousedown', function(ev){
        function onMousemove(ev){
            var ev = ev || window.event;
            obj.style.left = ev.clientX - disX + 'px';
            obj.style.top = ev.clientY - disY + 'px';
            preventDefault(ev);
            
        }

        function onMouseup(ev){
            removeEvent(document, 'mousemove', onMousemove);
            removeEvent(document, 'mouseup', onMouseup);
        }


        var ev = ev || window.event;
        var disX = ev.clientX - obj.offsetLeft;
        var disY = ev.clientY - obj.offsetTop;
        addEvent(document, 'mousemove', onMousemove);
        addEvent(document, 'mouseup', onMouseup);

        preventDefault(ev);

        
    })

}



var oDiv = document.getElementById('div1');
var oImg = document.getElementsByTagName('img')[0];

drag(oDiv);

addEvent(oDiv, 'mousemove', function(ev){
    var ev = ev || window.event;
    
    var oDrag = this;
    var oDragL = oDrag.offsetLeft;
    var oDragT = oDrag.offsetTop;
    var oDragW = oDrag.offsetWidth;
    var oDragH = oDrag.offsetHeight;

    var oTarget = oImg;
    var oTargetL = oTarget.offsetLeft;
    var oTargetT = oTarget.offsetTop;
    var oTargetW = oTarget.offsetWidth;
    var oTargetH = oTarget.offsetHeight;



    if( oDragL > oTargetL - oDragW  && 
        oDragL < oTargetL+ oTargetW &&
        oDragT > oTargetT - oDragH  &&
        oDragT < oTargetT + oTargetH
    ){//碰撞
        oTarget.src = 'img/2.jpg';

    }
    else{
        oTarget.src = 'img/1.jpg';
    }
})

</script>
</body>
</html>

相关文章

  • JavaScrip--事件应用

    事件应用 拖拽 拖拽原理 三大事件 -鼠标和Div的相对距离不变 把拖拽加到document上 如果拖得太快,会移...

  • JavaScrip--事件

    事件 事件冒泡 事件冒泡 : 当一个元素接收到事件的时候,会把他接收到的所有传播给他的父级,一直到顶层window...

  • JavaScrip--

    多重条件判断语句 数组 数组常用方法 通过标签获取元素 循环语句 去重 字符串处理的方法 字符串反转 定时器弹框 ...

  • Myeclipse 中jQuery代码提示

    第一步、右键项目选择Properties(属性) 第二步、选择Myeclipse-->JavaScrip-->In...

  • JavaScrip-->数组

    数组 在程序语言中数组的重要性不言而喻,JavaScript中数组也是最常使用的对象之一,数组是值的有序集合,由于...

  • JavaScrip-->Date

    Date 创建 Date 实例用来处理日期和时间。Date 对象基于1970年1月1日(世界标准时间)起的毫秒数。...

  • 005.Spring Boot ApplicationEvent

    Spring应用程序事件 一、定义应用程序事件 MessageEvent.java 二、发布应用程序事件 三、订阅...

  • 事件应用

    拖拽 拖拽原理 三大事件 -鼠标和Div的相对距离不变 把拖拽加到document上 如果拖得太快,会移出div,...

  • 事件应用

    拖拽 拖拽原理 三大事件 -鼠标和Div的相对距离不变 把拖拽加到document上 如果拖得太快,会移出div,...

  • July 30-day13-Python中Pygame

    触碰事件 有鼠标、键盘等等 对鼠标事件的应用 鼠标点击事件的应用(对鼠标的拖拽) 字体动画的效果 键盘事件的应用 ...

网友评论

      本文标题:JavaScrip--事件应用

      本文链接:https://www.haomeiwen.com/subject/gksiuttx.html