快速搞定前端JS面试 -- 第八章JS-Web-API-事件(事件绑定、事件冒泡、事件代理)

51 阅读4分钟

4. 通用的事件绑定函数

四、问题解答

1. 编写一个通用的事件监听函数?

2. 描述事件冒泡的流程?

3. 无限下拉的图片列表,如何监听每个图片的点击?


题目

  1. 编写一个通用的事件监听函数

  2. 描述事件冒泡的流程

  3. 无限下拉的图片列表,如何监听每个图片的点击?

知识点

  1. 事件绑定

  2. 事件冒泡

  3. 事件代理

一、事件绑定


通用的事件绑定函数

function bindEvent(elem, type, fn) {

elem.addEventListener(type, fn)

}

const p1 = document.getElementById('p1')

bindEvent(p1, 'click', event => {

event.stopPropagation() // 阻止冒泡

console.log('激活')

})

const body = document.body

bindEvent(body, 'click', event => {

console.log('取消')

// console.log(event.target)

})

const div2 = document.getElementById('div2')

bindEvent(div2, 'click', event => {

console.log('div2 clicked')

console.log(event.target)

})

获取触发元素: event.target输出事件是由哪个元素触发的

二、事件冒泡


****功能:****激活/取消状态切换(将取消事件绑定在body上,将激活事件绑定在p1上)

**对于嵌套事件输出的先后顺序:**冒泡,顺着DOM 结构向上级冒泡

如果不阻止事件冒泡,则,点击p1会输出:激活 取消(冒泡到body输出的取消)

阻止冒泡:stopPropagation()

<div id="div1">

<p id="p1">激活

<p id="p2">取消

<p id="p3">取消

<p id="p4">取消

<div id="div2">

<p id="p5">取消

<p id="p6">取消

<script src="./event.js">

三、事件代理


事件代理是在事件冒泡的机制下进行的

****1. 场景:****瀑布流

2. 例子描述

点击增加a标签,并且可以通过各种方式无限加载,因此div中不知道会有多少个a标签,无法一个一个绑定事件,因此这时候就可以把事件绑定到div上,当点击a标签时,会通过冒泡机制到div,再通过一些方法拿到a标签。即当数量比较多或者比较复杂,无法绑定事件时,可以将事件绑定到他的父元素上。

<div id="div3">

<a href="#">a1

<a href="#">a2

<a href="#">a3

<a href="#">a4

加载更多...

// 代理绑定

const div3 = document.getElementById('div3')

bindEvent(div3, 'click', event => {

event.preventDefault()    // 阻止默认行为(页面页面调转)

const target = event.targrt

if (target.nodeNamr === 'A') {

alert(target.innerHTML)

}

})

阻止默认行为:event.preventDefault()

3. 事件代理的优点

  1. 代码简介;(如果分析每个a标签,结构就比较复杂,要进行循环)

  2. 减少浏览器内存使用;(如果含有a标签比较多,每个都绑定一个事件监听,耗内存)

(但是不要滥用)

4. 通用的事件绑定函数

要求:能支持普通的监听,也能支持代理情况的监听

function bindEvent(elem, type, selector, fn) {  // selector是个css选择器

if (fn == null) {   // 判断只传入三个参数

fn = selector   

selector = null

}

elem.addEventListener(type, event => {

const target = event.target    

if (selector) {

// 有selector时是代理绑定

if (target.matches(selector)) {  // 判断DOM元素是否符合css选择器

文末

js前端的重头戏,值得花大部分时间学习。

JavaScript知识

推荐通过书籍学习,《 JavaScript 高级程序设计(第 4 版)》你值得拥有。整本书内容质量都很高,尤其是前十章语言基础部分,建议多读几遍。

前端电子书

另外,大推一个网上教程 现代 JavaScript 教程 ,文章深入浅出,很容易理解,上面的内容几乎都是重点,而且充分发挥了网上教程的时效性和资料链接。

学习资料在精不在多,二者结合,定能构建你的 JavaScript 知识体系。

面试本质也是考试,面试题就起到很好的考纲作用。想要取得优秀的面试成绩,刷面试题是必须的,除非你样样精通。

这是288页的前端面试题

288页面试题 开源分享:docs.qq.com/doc/DSmRnRG…