浅析js绑定同一个事件依次触发问题系列(一)

算了 还是上代码吧  记得写过这篇文章,但是找不到了(对,就是找不到了,算了再写一遍吧) 也是在群中有人问这个绑定不同事件 或者同一个事件的依次触发问题

个人建议如果是一个事件的话那么最好写成函数, 还有人问 如果我下一个函数 要依赖上一个函数执行是否完毕来执行(就是上一个函数如果执行完毕我才执行下一个函数,如果没有执行完毕 那么就不执行下一个函数)

我的思路是 定义一个变量   设置为false 用判断来写  这里就不写代码了 下一篇写这个代码 提一下   好了 扯淡扯远了  开始上代码

css部分如下

.test{width: 100%; height: 300px; background: red; }

html部分如下

<div id="test">aaaaaaa</div>

js部分

window.onload=function(){    var Test=document.getElementById(‘test‘)    Test.addEventListener("click",function(event){        event.preventDefault();        alert(1)    },false);

    Test.addEventListener("click",function(event){        alert(2)    },false);        Test.addEventListener("click",function(event){        alert(3)    },false)}

大家可以测试一下  触发 的顺序是依次进行的也就是 依次 弹出来 1   2    3   完毕。。。

但是这个东西是不兼容的(当然是坑爹的ie) 因为ie有自己的办法

咱们看一下ie是怎么样的(ie----> 与众不同)

window.onload=function(){
    var Test=document.getElementById(‘test1‘)
    Test.attachEvent("onclick",function(event){

        alert(1)
    },false);

    Test.attachEvent("onclick",function(event){
        alert(2)
    },false);

    Test.attachEvent("onclick",function(event){
        alert(3)
    },false)
}

他弹出来的效果  是 3   2   1   对   就是  这个顺序

那么咱们不能写一个这个东西要写两个吧 一个专门针对ie 啊于是大婶出现了

function addEvent(elm, evType, fn, useCapture) {
if (elm.addEventListener) {
elm.addEventListener(evType, fn, useCapture);//DOM2.0
return true;
}
else if (elm.attachEvent) {
var r = elm.attachEvent(‘on‘ + evType, fn);//IE5+
return r;
}
else {
elm[‘on‘ + evType] = fn;//DOM 0
}
}

写的有点乱   自己还能看  唉

时间: 2024-11-07 22:58:15

浅析js绑定同一个事件依次触发问题系列(一)的相关文章

js绑定touch事件

定义: var touchEvents = { touchstart: "touchstart", touchmove: "touchmove", touchend: "touchend", /** * @desc:判断是否pc设备,若是pc,需要更改touch事件为鼠标事件,否则默认触摸事件 */ initTouchEvents: function () { if (isPC()) { this.touchstart = "mouse

JS绑定回车事件

1.BODY 上绑定 onkeyup="LoginEnter(event)" 2.obj.keyCode==number number为键盘的KEY值 Login();为调用方法 obj.returnValue=falese; 防止后面的操作 function LoginEnter(obj) {            if (obj.keyCode == 13) {                Login();                obj.returnValue = fal

css解决ios 绑定click事件不触发问题

<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>test</title> <style type="text/css"> .test { font-size: 60px; text-align: center; height: 300px; background: red; cursor: pointer;

关于js中对事件绑定与普通事件的理解

普通事件指的是可以用来注册的事件: 事件绑定是指把事件注册到具体的元素之上. 通俗点说: 普通事件:给html元素添加一个特定的属性(如:onclick): 事件绑定:js代码中通过标记(id  tag class)获取元素,给元素添加特定的方法(如:onclick): 扩展:事件监听addEventListener事件可以绑定多次事件,并进行触发 div1.onclick = function(){}; <button onmouseover = " "></but

JS的事件绑定、事件流模型

.t1 { background-color: #ff8080; width: 1100px; height: 40px } 一.JS事件 (一)JS事件分类 1.鼠标事件:click/dbclick/mouseover/mouseout2.HTML事件: onload/onunload/onsubmit/onresize/onchange/onfoucs/onscroll3.键盘事件: keydown:键盘按下时触发 keypress:键盘按下并抬起的瞬间触发. keyup:键盘抬起触发[注意

JS中的事件绑定,事件捕获,事件冒泡以及事件委托,兼容IE

转载请注明出处:http://www.cnblogs.com/zhangmingze/p/4864367.html ● 事件分为三个阶段:   事件捕获 -->  事件目标 -->  事件冒泡 ● 事件捕获:事件发生时(onclick,onmouseover--)首先发生在document上,然后依次传递给body.……最后到达目的节点(即事件目标). ● 事件冒泡:事件到达事件目标之后不会结束,会逐层向上冒泡,直至document对象,跟事件捕获相反 1.onlick -->事件冒泡,

JS学习笔记-事件绑定

一.传统事件模型 传统事件模型中存在局限性. 内联模型以HTML标签属性的形式使用,与HTML混写,这种方式无疑造成了修改以及扩展的问题,已经很少使用了. 脚本模型是将事件处理函数写到js文件中,从页面获取元素进行对应事件函数的绑定以触发执行.但也存在不足之处: 1.一个事件绑定多个事件监听函数,后者将覆盖前者. 2.需要限制重复绑定的情况 3.标准化event对象 二.现代事件绑定 DOM2级事件定义了两个方法用于添加.删除事件:addEventListener().removeEventLi

JS 事件绑定、事件监听、事件委托详细介绍

事件绑定 要想让 JavaScript 对用户的操作作出响应,首先要对 DOM 元素绑定事件处理函数.所谓事件处理函数,就是处理用户操作的函数,不同的操作对应不同的名称. 在JavaScript中,有三种常用的绑定事件的方法: 在DOM元素中直接绑定: 在JavaScript代码中绑定: 绑定事件监听函数. 在DOM中直接绑定事件 我们可以在DOM元素上绑定onclick.onmouseover.onmouseout.onmousedown.onmouseup.ondblclick.onkeyd

JS 中的事件绑定、事件监听、事件委托

事件绑定 要想让 JavaScript 对用户的操作作出响应,首先要对 DOM 元素绑定事件处理函数.所谓事件处理函数,就是处理用户操作的函数,不同的操作对应不同的名称. 在JavaScript中,有三种常用的绑定事件的方法: 在DOM元素中直接绑定: 在JavaScript代码中绑定: 绑定事件监听函数. 在DOM中直接绑定事件 我们可以在DOM元素上绑定onclick.onmouseover.onmouseout.onmousedown.onmouseup.ondblclick.onkeyd