首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Js 事件委托(事件代理)

一、概述 事件委托,又叫事件代理。事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型的所有事件。 例子:有三个同事预计会在周一收到快递。...为签收快递,有两种办法:一是三个人在公司门口等快递;二是委托给前台MM代为签收。现实当中,我们大都采用委托的方案(公司也不会容忍那么多员工站在门口就为了等快递)。...,就会将所有的操作放到js程序里面,与dom的操作就只需要交互一次,这样就能大大的减少与dom的交互次数,提高性能; 每个函数都是一个对象,是对象就会占用内存,对象越多,内存占用率就越大,自然性能就越差了...三、事件委托原理 事件委托利用的是事件冒泡原理,将事件绑定到父级元素上,当点击子元素时,通过事件冒泡将事件传递到父级元素。  四、总结: 那什么样的事件可以用事件委托,什么样的事件不可以用呢?...适合用事件委托的事件:click,mousedown,mouseup,keydown,keyup,keypress。

11.4K30

js事件委托的理解 转

今日看下拉列表时用到事件委托,特意在网上搜查了一些资料, http://www.cnblogs.com/liugang-vip/p/5616484.html  这篇文章写的很详细,非常感谢作者。...事件委托也叫事件代理,事件委托就是利用事件冒泡,指定一个事件处理程序,就可以管理某一类型的所有事件,何为事件冒泡呢,就是从事件最深的节点开始,然后逐步向上传播事件,最大的优点是提高性能 一般的做法 <ul...i<aLi.length;i++){ aLi[i].onclick = function(){ alert(123); } } } 事件委托写法...不适合的就有很多了,focus,blur之类的,本身就没用冒泡的特性,自然就不能用事件委托了。...我的理解是:事件委托都是在外围的div添加事件,当点击内部的一个元素时,即使这个元素没有onclick事件,依然会从内到外执行onclick事件,js中外部div 添加事件的函数内 var ev = ev

99220

JS篇(007)-事件委托是什么

解析: 1、那什么样的事件可以用事件委托,什么样的事件不可以用呢? - 适合用事件委托的事件:click,mousedown,mouseup,keydown,keyup,keypress。...- 不适合的就有很多了,举个例子,mousemove,每次都要计算它的位置,非常不好把控,在不如说 focus,blur 之类的,本身就没用冒泡的特性,自然就不用事件委托了。...2、为什么要用事件委托 - 1.提高性能 苹果 香蕉 凤梨 // good document.querySelector...3、事件冒泡与事件委托的对比 - 事件冒泡:box 内部无论是什么元素,点击后都会触发 box 的点击事件 - 事件委托:可以对 box 内部的元素进行筛选 4、事件委托怎么取索引?... aaaaaaaa 事件委托了 点击当前,如何获取 这个点击的下标 cccccccc<

1.7K10

C#委托五(自定义事件)

在 .NET Framework 类库中,事件是基于 EventHandler 委托和 EventArgs 基类的 C#类库中自带了一大堆事件,尤其那些控件。...而对于我说到的这个底层触发上层的问题,那么绝大多数是需要自定义事件的。(库中自带事件的使用我就不讲了,如果这个你不会的话,未免对不起观众了。)...所以下面就开始着重讲讲自定义事件的问题: 事件是类和对象向外界发出的消息,事件的执行是通过事件委托的方式,调用我们所准备好的处理方法。...要响应某些事件并针对某些事件执行我们指定的方法,需要做到以下几步: 声明委托、事件 ///定义一个委托 public delegate void TestEventHandler...{ KeyToRaiseEvent = keyToRaiseEvent; } } ///定义一个委托

1.1K10

Qt TableWidget 控件 及自定义委托

上次和大家分享了TreeWidget的简单使用,本次和大家分享下TableWidget的简单应用以及项目视图中的自定义委托。...自定义委托 很久之前和大家分享了Qt Model/View的简便类与预定义模型,之后还差自定义模型和自定义委托,今天就把自定义委托补上。...使用自定义委托 ui->tableWidget->setItemDelegateForColumn(2,new ComboBoxDelegate); 咦,这就可以了啊。貌似还不错!...也可以设置所有单元格都使用自定义委托,不过自定义委托里面的限制条件不要忘记修改。另外,如果使用自定义委托,双击单元格获得单元格数据内容时,就要加限定了。 最后效果: ?...后记总结: 这次虽然是简单使用Qt Model/View 的自定义委托功能,但是其他复杂的功能总体流程也是如此。见微知著,亦或如此吧! 最后: 学不可以已!

2.1K10

26.QT-模型视图之自定义委托

初探自定义委托类  委托属于视图的子功能 视图主要负责组织具体数据项的显示方式(是列表方式,还是树形方式,还是表格方式) 委托主要负责具体数据项的显示和编辑,比如用户需要编辑某个数据时,则需要弹出编辑框...在模型视图中,会默认提供一个QStyledItemDelegate类,供用户编辑数据 也可以通过继承QItemDelegate父类,实现自定义委托功能 QAbstractItemDelegate类中的关键虚函数...editor->setGeometry(option.rect); } 然后,再通过视图的setItemDelegate(QAbstractItemDelegate * delegate )成员函数设置我们自定义委托类对象即可...深入自定义委托类 之前我们写的自定义委托,每次都需要双击某个数据项,才能弹出编辑器 那如何让委托一直呈现在视图显示上呢?...步骤如下: 重写委托类的paint成员函数 在paint()中,通过QApplication::style()->drawControl()来自定义数据显示方式,比如绘制按钮 重写委托类的editorEvent

2K20

《你不知道的JavaScript》:js面向委托设计

回顾下js原型继承,js版的继承与传统面向对象的继承的区别主要是不复制对象,而是通过对象的内置属性[[Propertype]]来关联需要“继承”的对象,这样当引擎在对象中查找不到预期的属性或方法时,应付通过...所以我们可以这样理解js的原型继承机制,其本质就是对象间的关联关系。 好,弄明白了这个对象间的关联关系,才能理解js中的对象委托。...所以在写js时,心里要有个思想转换,要从类思维模式转为委托思维模式。...通过[[Propertype]]将oneStudent对象委托到Students对象,实现js版的继承。...这样仔细一对比,是不是类设计模式和委托设计模式的区别就很明显了? 类有行为的复制过程。而委托没有,只是通过对象关联产生的委托关系来调用被委托对象中的行为。

99930

C# 委托一(委托基础)

委托可以这样来理解:它是一种数据类型,和引用类型类似,不过和一般的类相比,委托的实例不是在堆中的数据,而是一个方法。...委托类似于引用类型,和C++中的函数指针很相似,但是不同之处就在于,它不是存在于堆中的。正是有了委托我们才得以将函数打包成一个变量进行传递。...实例结束,总结以下几点: Ø 在C#中,所有的委托都是从System.MulticastDelegate类派生的。 Ø 委托隐含具有sealed属性,即不能用来派生新的类型。...Ø 委托最大的作用就是为类的事件绑定事件处理程序。 Ø 在通过委托调用函数前,必须先检查委托是否为空(null),若非空,才能调用函数。 Ø 在委托实例中可以封装静态的方法也可以封装实例方法。...Ø 在创建委托实例时,需要传递将要映射的方法或其他委托实例以指明委托将要封装的函数原型(.NET中称为方法签名:signature)。

60740

C#委托二(委托类型)

我们都应该清楚,在使用委托之前,先要定义一个委托类型,如下所示: delegate int MyDelegate(int a,int b); MyDelegate md =null; 既然叫做委托类型,...MulticastDelegate类 MultiDelegate类是一个特殊类(Special Class),和System.Delegate类一样,该类只能够被编译器以及内置的工具类所继承,我们自定义的类是不能够显式的继承自该类的...MultiDelegate类当中可以包括一个委托的链表,这个表中,可以包括一个或多个元素(每个元素都是一个委托),我们可以将这个表称为调用链。...关于多播委托的说明,我们会在后面的内容中进行讲解。...Invoke方法 为了解释Invoke方法,我们先来回顾一下,当一个委托指向了一个方法时是如何调用的,代码如下所示: int c = this.md(a,b); 我们在调用委托,并执行该委托所指向的方法时

41510

委托与事件-委托详解(一)

前言   说起委托和事件,我就想起了再学校的时候,当时死记硬背去记什么是委托什么是事件。记得当时蝼某人问我,委托是什么?...方法是具体做事实现功能,委托只是命令而已。   我们具体使用委托来实现刚刚那个委托蝼某人去买水的程序设计。...在这个例子中都是返回的string,都是无参数的 委托链(多播委托)   上面我们简单的介绍了下委托及其用法,这里我们可以了解一下委托链,顾名思义,委托链也就是委托连续,啥意思呢?...,先去买水然后顺带买了辣条,委托链(多播委托)可以使用+=来增加委托中调用的方法,同理也可使用-=来删除委托中调用的方法.   ...注意,委托链(多播委托)--委托的签名必须返回void,否则就只能得到委托调用的最后一个方法的结果。

1.1K20

委托与事件-委托事件案例(三)

前言   这两天一直在想如何结合实际案例来结束委托与事件的讲解,下面讲解两个事例,用来加深对委托及事件的理解。 事例一(分页功能)   本场景是用来讲解使用的,具体内容功能需自行填补实现。...用委托加事件来实现分页功能的通用。按上一节讲解中的逻辑处理,分为订阅者和发布者,一样的可以先定义订阅者感兴趣的对象,然后发布者,订阅者。再就是主程序调用。...// /// 定义发布者 /// public class PageActionPubliser { //定义委托...public event PageActionEventHandler PageAction; //定义保护方法判断委托事件是否为空,传入参数e类型为EventArgs...; } } } 谨记,事件基于委托,为委托提供了一种发布/订阅机制。理解发布订阅机制就会容易多了。一旦理清楚,发现好像也并不是很难的。

83420

C#委托三(多播委托)

有的时候,我们想要调用一个委托,但同时可以执行多个方法(自定义事件中最为常见),比如,一个工作文档生成之后,系统要将生成文档日志,而且还要被保存到数据库中,对于以上二个操作,如果只想调用一个委托,就可以顺序完成...,那么使用多播委托,就可以实现。...如果调用多播委托,就可以按顺序连续调用多个方法。为此,委托的签名就必须返回 void (否则,返回值应送到何处?)...(当委托只包含一个方法的时候,其返回类型的声明可以参照所封装的方法,不一定必须是void)。实际上,如果编译器发现某个委托返回 void ,就会自动假定这是一个多播委托。...因为所有的委托都继承自MulticastDelegate,因此所的委托都具备多播特性。

1K30

委托模式

委托模式 委托模式就是利用事件的冒泡机制把一个或者一组元素的事件委托到它的父层或者更外层元素上,准确来说不属于通常定义的设计模式范畴,但事件委托是一种非常有用的代码构建技巧。...描述 事件委托委托模式就是利用事件的冒泡机制把一个或者一组元素的事件委托到它的父层或者更外层元素上,真正绑定事件的是外层元素,当事件响应到需要绑定的元素上时,会通过事件冒泡机制从而触发它的外层元素的绑定事件上...IE6、IE7、IE8等浏览器事件过多会影响用户体验,而对于这种需求完全可以使用事件委托,将点击事件冒泡到外层的父元素去处理,在父元素取得冒泡的元素再去调整DOM结构。...另外,使用事件委托还可以对于未来的更改有一定的预见性,例如我们有一行文字,点击弹出文字内容,而如果我们再在这行文字下加入一行文字,依旧需要为其添加点击事件才能做到点击弹出效果,如果我们使用事件委托机制,...下面是一个简单的事件委托的示例。 <!

67010
领券