js事件相关面试题
说是面试题,其实也相当于是对js事件部分知识点的一个总结。简单内容一笔带过,了解详情我都给出了参考链接,都是之前写的一些相关文章。JavaScript本身没有事件模型,但是环境可以有。
DOM:addEventListener、removeEventListener、dispatchEvent
IE-DOM:attachEvent、detachEvent、fireEvent
jQuery:on、off、trigger
一、描述js里事件的三个阶段
捕获、处于目标阶段、冒泡阶段(IE8以下只支持冒泡)
了解更多可参考:事件流
二、IE和W3C标准 绑定事件的区别?参数分别是什么?以及IE事件对象中的e有什么区别
标准:
/*
参数:
eventName:事件的名字
function:事件处理函数
Boolean:捕获或者冒泡,默认是false冒泡
*/
/*事件对象e作为参数传入*/
addEventListener(eventName,function(e){
},false);
IE8以下
/*
参数:
onEvnet:是事件处理程序的名字,而不是事件名,就是说在事件名前加上on
function:事件处理函数
*/
/*
e=window.event,事件event是window的一个属性
*/
attachEvent(onEventName,function(){
var e=window.event;
})
了解更多可以参考事件处理程序
三、事件代理的原理及优缺点
原理:靠事件冒泡实现的
优点:
- 大量减少内存占用,减少事件注册
- 新增子对象时无需再次对其绑定事件,对于动态内容不符尤其适用
缺点:
适用于表格/列表等重复性dom元素,事件代理用不好可能出现事件误判,即本不应该触发事件的元素被绑定了事件
四、手写原生js实现事件代理
要求:兼容浏览器
考点:事件对象e,IE下事件对应的属性名。
重点是要说到target,currentTarget以及IE下的srcElement和this。
三、四2部分具体可参考:事件的典型应用事件代理
五、实现事件模型
核心需求:可以对某一个事件名称绑定多个事件处理函数,然后触发这个事件名称时,依次按照绑定顺序触发相应的事件处理函数。
原理:写一个类或者匿名函数,有两个函数,一个bind,一个trigger,分别实现绑定事件和触发事件。
在bind和trigger函数外层作用域创建一个字典对象,用于存储注册的事件名称和事件处理函数列表。
bind时,如果字典没有则创建一个,key是事件名称,value是数组,里面放着当前注册的响应函数。
如果字段汇总有,那么就直接push到数组中即可。
trigger时调出来依次触发事件响应函数即可。
还有很多细节:
触发响应函数时的上下文应该是什么?【我觉得应该就是谁触发了这个事件处理函数this就是谁,大家有懂的可以评论一下】
触发响应函数的参数列表应该是什么?
如果要求把trigger的参数列表都传到响应函数中还要考虑把arguments对象转化为纯数组才行。
js中自定义事件模型
function Emitter() {
this._listener = {}; //_listener[自定义的事件名] = [所用执行的匿名函数1, 所用执行的匿名函数2]
} //注册事件
Emitter.prototype.bind = function(eventName, funCallback) {
var listenersArr = this._listener[eventName] || []; ////this._listener[eventName]没有值则将listener定义为[](数组)。
listenersArr.push(funCallback);
this._listener[eventName] = listenersArr;
}
//触发事件
Emitter.prototype.trigger = function(eventName) {
//未绑定事件
if (!this._listener.hasOwnProperty(eventName)) {
console.log('you do not bind this event');
return;
}
var args = Array.prototype.slice.call(arguments, 1); ////args为获得除了eventName后面的参数(最后被用作注册事件的参数)
var listenersArr = this._listener[eventName];
var _this = this;
if (!Array.isArray(listenersArr)) return; ////自定义事件名不存在 listenersArr.forEach(function(callback) {
try {
callback.call(_this, args);
} catch (e) {
console.log(e);
}
});
}
//解绑
Emitter.prototype.unbind = function(eventName, callback) {
this._listener.hasOwnProperty(eventName) && delete this._listener[eventName];
callback && callback();
}
测试用例
var emitter = new Emitter();
emitter.bind("selfEvent", function() {
console.log("第一个绑定");
Array.prototype.forEach.call(arguments, function(item) {
console.log(item);
});
});
emitter.bind("selfEvent", function() {
console.log("第二个绑定");
Array.prototype.forEach.call(arguments, function(item) {
console.log(item);
});
});
emitter.trigger('selfEvent', 'a', 'b', 'c');
emitter.unbind('selfEvent', function() {
console.log("解除绑定");
});
emitter.trigger('selfEvent', 'a', 'b', 'c');
运行结果
六、事件广播(dispatchEvent)
dispatchEvent是js的事件触发器,事件触发器就是用来触发某个元素下的某个事件。
可以自定义事件,通过触发器触发。
<p id="pElement">事件被触发后文字变红</p> <script>
var pElement=document.getElementById("pElement"); var event=new Event('selfEvent');
pElement.addEventListener('selfEvent', function (e) {
alert(e.type); //selfEvent
this.style.color="red";
},false);
pElement.dispatchEvent(event); </script>
如果初始化自定义事件时需要添加一些额外的数据,可以用CustomEvent构造函数。
var event=new CustomEvent('lxyEvent',{'detail':'liuxiaoyan'}); //detail属性值即自定义数据
pElement.addEventListener('lxyEvent', function (e) {
alert(e.type+ e.detail);
this.style.color="red";
},false);
pElement.dispatchEvent(event);
参考:
http://www.cnblogs.com/pcd12321/p/5223347.html
http://www.cnblogs.com/1wen/p/5640997.html
本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/6767655.html有问题欢迎与我讨论,共同进步。
js事件相关面试题的更多相关文章
- js 事件相关 事件处理 封装 事件封装 DOM 0 2 3 级事件
1.绑定 function(element, type, handler){ if (element.addEventListener) { element.add ...
- javascript 事件相关使用总结01
javascript 事件相关使用总结01 这里总结一下js事件相关的经验. addEventLinstener()介绍 注册事件最基础的函数是这个 target.addEventListener(t ...
- js 事件对象相关笔记
事件对象 event就是一个事件对象 写到我们的监听函数的括号里面 当形参来看 事件对象只有有了事件才存在,他是系统给我们自动创建的 不需要我们传递参数 事件对象是我们事件的一 ...
- JS—事件对象
在触发DOM上的某个事件时,会产生一个事件对象event.这个对象中包含着所有与事件有关的信息.包括导致事件的元素,事件的类型以及其他与特定事件相关的信息. 举例鼠标操作导致的事件对象中,会包含鼠标位 ...
- JS事件对象与事件委托
事件对象 包含事件相关的信息,如鼠标.时间.触发的DOM对象等 js默认将事件对象封装好,并自动的以参数的形式,传递给事件处理函数的第1个参数,如下: document.getElementsByTa ...
- 三言两语之js事件、事件流以及target、currentTarget、this那些事
厉害了我的哥--你是如此简单我却将你给遗忘 放假前再看某文档,里边提到两个我既熟悉又陌生的概念target.currentTarget,说他熟悉我曾经看到过这两个事件对象的异同处,说他陌生吧?很不 ...
- js 事件大全
Js事件大全一般事件 事件 浏览器支持 描述onClick IE3|N2|O3 鼠标点击事件,多用在某个对象控制的范围内的鼠标点击onDblClick IE4|N4|O 鼠标双击事件onMouseDo ...
- JS事件
JS事件: 声明:为了事件对象event跨浏览器兼容: var oEvent==ev||event; 所以在下面用到 event 的地方都用 oEvent 代替 1)doucument的 ...
- JS事件模型小结
三种事件模型:原始事件模型(DOM0),DOM2事件模型,IE事件模型: 不同点: 事件程序的注册(给HTML元素所对应的JS对象绑定事件) 事件传播的过程 事件模型的注册: 一.原始事件模型(没有兼 ...
随机推荐
- ZooKeeper的简单理解
1 ZooKeeper的一致性特点 概念 描述 备注 顺序一致性 以ZXID来保证事务的顺序性 原子性 以ZAB保证原子操作,要么成功,要么失败 单一视图 无论客户端从哪个服务器获取到关于应用的数据都 ...
- PHP语言开发微信公众平台(订阅号)之开启基本功能及获得可用的服务器地址(2)
1.开启群发功能(单击功能菜单里的"群发功能",并在右侧页面中点击"同意以上声明") 2.(1)在开启开发者模式之前需要完善个人资料(完成头像上传即可) (2) ...
- web从入门开始(5)-----表单
1. 表单的概念 是用来获取客户端用户数据的(信息)的.如:注册表单,查询表单,登录表单等. 2. 表单的工作原理 1.浏览有表单的网页,填写一些必要的信息,然后单击某个按钮,进行提交. 2.这 ...
- 一些关于Canny边缘检测算法的改进
传统的Canny边缘检测算法是一种有效而又相对简单的算法,可以得到很好的结果(可以参考上一篇Canny边缘检测算法的实现).但是Canny算法本身也有一些缺陷,可以有改进的地方. 1. Canny边缘 ...
- python全栈开发第10天-正则表达式
正则表达式 正则表达式,又称规则表达式.(英语:Regular Expression,在代码中常简写为regex.regexp或RE),计算机科学的一个概念.正则表通常被用来检索.替换那些符合某个模式 ...
- cuda学习笔记——deviceQuery
main(int argc, char **argv):argc是参数个数,**argv具体的参数,第0个是程序全名 cudaError_t类型:记录cuda错误,值为cudaSuccess则正确执行 ...
- 知问前端——html+jq+jq_ui+ajax
**************************************************************************************************** ...
- nfs mount:reason given by server: Permission denied
遇到nfs mount的问题,以前从未遇到过,问题出的很奇怪,现象是 mount: 10.1.10.22:/cicro failed, reason given by server: Permissi ...
- django出现__init__() got an unexpected keyword argument 'mimetype‘ 问题解决
这种问题好多新手按照djangobook学习的时候应该都遇到过,是因为这是老的django的写法,新的django已经升级改变了很多东西. 处理方法如下: I think you are not us ...
- Vue.js 2.2 卡片api
给vue开发者和爱好者发送点福利! 卡片上一共117个api,方便查阅 网址: https://vuejs-tips.github.io/cheatsheet Github: https://gith ...