谈起JavaScript的 事件,事件冒泡、事件捕获、事件委托这三个话题,无论是面试还是在平时的JavaScript的开发中,都很难避免,不太熟悉JavaScript中的这些事件的同学,我们一起来看看本篇文章吧!事件流 JavaScript与HTML之间的交互是通过事件实现的。事件,就是文档或浏览器窗口中发生的一些特定的交互瞬间。可以使用侦听器来预订事件,以便事件发生时执行相应的代码。 事件流的起源:就是在浏览器发展到第四代的时候,浏览器...
三者的关系是怎样的呢一、事件捕获和冒泡是现代浏览器的执行事件的两个不同阶段二、事件委托是利用冒泡阶段的运行机制来实现的事件冒泡和捕获的运行图运行条件:当一个事件发生在具有父元素的的元素上时,现代浏览器根据事件添加时的设置来执行(冒泡或者捕获)通过 addEventListener() 的第三个属性来设置事件是通过捕获阶段注册的(true),还是冒泡阶段注册的(false)。默认情况下是false。事件冒泡从实际操作的元素(事件)向...
本文主要为大家带来一篇浅谈事件冒泡、事件委托、jQuery元素节点操作、滚轮事件与函数节流。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。一、事件冒泡定义事件冒泡是指在一个对象触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象...
概念事件冒泡:事件促发的最深层元素首先接收事件。然后是它的父元素,依次向上,直到document对象最终接收到事件。尽管相对于html元素来说,document没有独立的视觉表现,他仍然是html元素的父元素并且事件能冒泡到document元素。 随便也说一下事件捕获。 事件捕获:事件首先发生在DOM树的最高层对象(document)然后往最深层的元素传播。(注意IE6只有冒泡,没有捕获) 事件委托:我认为事件委托是利用冒泡原理,把事件的监听转换到...
简单说下事件委托与阻止冒泡
html:全部
纽约
洛杉矶
拉斯维加斯
夏威夷
旧金山
奥兰多
西雅图 js:$("ul[data-type='cityPick']").on('click',function(){
alert("父元素ul被点击");
});
$("ul[data-type='cityPick']").on('click','li',function(){
alert("子元素li被点击");
});当点击具体的li元素时,发现ul的事件也被触发了,这是我们不想看到的。
解决:$("ul[data-type='cityPick']").on('click',function(){
al...
首先,大家都知道,jQuery事件触发时有2种机制,一种是事件委托,另一种是事件冒泡(IE情况暂时不考虑)。拿click事件做例子,先附上一段代码:
html:我是按钮style:
.hid{display:none;
}script:$('#box').click(function(){$(‘#btn').toggleClass(‘hid');
})
$('#btn').click(function(){alert('btn');
})这段代码的本意是,当我点击#btn的时候,我要alert出来“btn”字符串,而当我点击#box的时候,我要把#btn隐藏,但是,在...
一、事件冒泡定义
事件冒泡是指在一个对象触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,甚至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层级的最顶层,即document对象(有些浏览器是window).。
二、事件冒泡的作用
事件冒泡允许多个操作被集中处...
说下闭包的由来
function a() {
var i = 0;
function b() {
console.log(i);
}
return b;
}
var c = a();
c(); 一般来说,当一个函数内部匿名函数用到了自己的变量,并且这个匿名函数被返回了,这就建立了一个闭包,比如上面的代码这个时候,就算a调用结束被销毁,i也会存在不会消失当a定义时,js解释器会将函数a的作用域链设置为定义a时所在环境当执行a时,a会进入相应的执行环境,执行环境创建后才会有作用域scope属性,然后创建...
首先,大家都知道,jQuery事件触发时有2种机制,一种是事件委托,另一种是事件冒泡(IE情况暂时不考虑)。拿click事件做例子,先附上一段代码:
html:
<body>
<div id="box">
<p id="btn">我是按钮</p>
</div>
</body>
style:
.hid{display:none;
}script:
$(#box).click(function(){$(‘#btn).toggleClass(‘hid);
})
$(#btn).click(function(){alert(btn);
})这段代码的本意是,当我点击#btn的时候,我要alert出来“btn”字符串...
简单说下事件委托与阻止冒泡
html:
<ul class="clearfix" data-type="cityPick">
<li class="active_sort_opts" data-id="0">全部</li>
<li data-id="88">纽约</li>
<li data-id="119">洛杉矶</li>
<li data-id="138">拉斯维加斯</li>
<li data-id="84">夏威夷</li>
<li data-id="120">旧金山</li>
<li data-id="105">奥兰多</li>
<li data-id="118">西雅图</li>
</ul>js:
$("ul[data-type=cityPick]").on(click,function...
事件捕获事件捕获中,父级元素先触发,子集元素后触发
事件会从最外层开始,直到具体的元素,比如click的捕获过程document->html->body->div->p事件冒泡事件冒泡时,子元素先出发,父级元素后触发
元素自身事件被触发后,如果父元素有相同的事件,那么元素本身的触发状态就会传递,就是冒到父元素,父元素相同事件也会一级级向外触发
默认情况下,所有事件处理程序都是在冒泡阶段注册的
如果想早捕获阶段注册事件,通过addEventLis...
事件冒泡
IE的事件流叫做事件冒泡。顾名思义当事件发生后,事件就开始从里向外传播,查看下方代码:
<html lang="en"><head><meta charset="UTF-8"><title>Document</title></head><body><div id="myDiv"></div></body>
</html>如果点击页面中的 <div> 元素,那么这个 chick 事件就会按照如下顺序传播:click 事件 在 直系DOM 树的每一级节点都会发生(自下而上),直到 document 对象。
事件委托
又称事件代理。对“事件处理程序过...
事件冒泡
事件冒泡(event bubbling),即事件开始时由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到较为不具体的节点。
比如以下这个最基础的html结构:
<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title></head><body><div></div></body>
</html>
<script></script>如果单击了页面中的< div >元素,那么这个click事件沿DOM树向上传播,在每一个节点上都会发生,按照如下顺序传播: 1、div...