JavaScript 基础 学习 (四)

解绑事件

dom级 事件解绑

​ 元素.on事件类型 = null

​ 因为赋值的关系,所以给事件赋值为 null 的时候

​ 事件触发的时候,就没有事件处理函数执行了

dom2级 事件解绑

​ 元素.removeEVentListener('事件类型',要移出的事件处理函数)

​ 元素.detachEvenbt('on事件类型', 要移除的事件处理函数)

事件的传播

​ 当你在一个元素上触发行为的时候

你这个行为会按照元素 结构父级 的顺序, 逐层 向上 传播

就相当于在父级身上也触发了这个行为

就相当于在父级的父级身上也触发了这个行为

直到 window 为止, 都触发了同样的行为

事件的 目标

目标: 当事件触发, 事件处理函数执行的时候, 准确触发事件的那个元素

​ 当 window 的点击事件触发的时候

​ 是因为点击了谁, 而触发的

​ 是因为点击自己触发的, 还是因为点击某一个子元素, 通过传播来触发的

​ 准确触发事件的元素, 我们叫做事件的 目标

​ 获取事件的目标, 在 事件对象 里面有记录

​ 事件对象就是一个对象数据结构, 里面记录了本次事件的信息

事件目标的获取

​ 在事件对象里面通过一个属性来获取

target 目标 ---- 标准浏览器

srcELement 目标 ---- IE 低版本

​ 兼容的写法

var target = e.target || e.srcElement

事件的冒泡和捕获

​ 就是事件触发的顺序

冒泡: 按照从 目标 到 window 的顺序来执行所有的同类型事件

捕获: 按照从 window 到 目标 的顺序来执行所有的同类型事件

​ 我们怎么让事件按照冒泡或者捕获的顺序执行

IE 低版本只能按照冒泡的顺序执行, 没有办法设置捕获

​ 标准浏览器, 通过 addEventListener 的第三个参数来决定是冒泡还是捕获

​ 第三个参数, 是 布尔值

​ 默认是 false, 表示冒泡

​ 选填是 true, 表示捕获(一般很少使用)

阻止事件传播

例子:

​ 确实有一个 html 嵌套的结构

​ 我点击里面元素的时候, 需求打印 需要做的事情1

​ 我点击外面元素的时候, 需求打印 需要做的事情2

​ 现在当我点击里面元素的时候, 回把两个事件处理函数都执行了

​ 但是我并不需要, 我就是点击谁触发谁的事件就好

分析问题:

​ 当你点击 inner 元素的时候, 因为事件的传播

​ 导致你也是点击在了 center 元素身上

​ 所以 center 身上的点击事件也会触发

解决问题:

​ 只要我不让事件传播, 那么我点击在 inner 身上的时候

​ 因为禁止了事件的传播, 那么就相当于没有传播

​ 那么就不会触发 center 身上的点击事件了

怎么阻止事件传播 - 利用事件对象里面的内容

e.stopPropagation() 停止传播 ---- 标准浏览器

e.cancelBubble = true 确认取消冒泡 ---- IE 低版本

兼容处理

​ 如果两个都是属性, 我们可以使用 或 运算符兼容

​ 如果一个属性一个方法, 或者两个都是方法, 那么我们就要用 if 条件来写

​ 判断事件对象里面有没有 e.stopPropagation 这个函数, 有就执行, 没有就用另一个

if (e.stopPropagation) {

e.stopPropagetion()

} else {

e.cancelBubble = true

}

e.stopPropagation 肯定是一个函数才能 e.stopPropagetion()

​ 判断 e.stopPropagetion 是不是一个函数就完了

​ 在标准浏览器下他是一个函数, 你把他写在 if 条件里面就是 true

​ 在 IE 低版本没有这个东西, 他是 undefined, 你把他写在 if 条件就是 false

事件委托

​ 把我自己的事件, 委托给别人帮我干

​ 我的事件交给别人来干, 那么我就不用在自己身上绑定事件了

例子: 按照目前的 页面结构

​ 我点击每一个 li 都会因为事件冒泡而触发 ul 的点击事件

​ 现在, 我只要给 ul 绑定一个点击事件, 那么我点击每一个 li 的时候都会触发

mouseover 和 mouseenter 的区别

mouseovermouseout 的移入移出会向上传播

mouseentermouseleave 的移入移出不会向上传播

浏览器默认行为

​ 不需要绑定, 浏览器天生自带的一个行为

表单提交: 不需要绑定提交时间, 只要点击 submit 按钮, 会自动提交跳转页面

a 超链接: 不需要绑定点击事件, 只要点击 a 标签就会跳转连接

鼠标右键: 不需要绑定右键单击事件, 只要你单击鼠标右键, 就会出现一个菜单

文本选中: 不需要绑定选中事件, 只要你框选, 就会选中页面中的文本内容

阻止浏览器默认行为

1. e.preventDefault() 标准浏览器

2. e.returnValue = false IE 低版本

3.通用的方法 return false

JavaScript 基础 学习 (四)的更多相关文章

  1. JavaScript基础学习(四)—Object

    一.Object的基本操作 1.对象的创建      在JavaScript中,创建对象的方式有两种:构造函数和对象字面量.      (1)构造函数 var person = new Object( ...

  2. JavaScript 基础学习1-day14

    JavaScript 基础学习1 知识预览JavaScript概述二 JavaScript的基础三 JavaScript的对象BOM对象DOM对象实例练习js扩展 JavaScript概述 JavaS ...

  3. JavaScript 基础 学习(三)

    JavaScript 基础 学习(三) 事件三要素 ​ 1.事件源: 绑定在谁身上的事件(和谁约定好) ​ 2.事件类型: 绑定一个什么事件 ​ 3.事件处理函数: 当行为发生的时候,要执行哪一个函数 ...

  4. 48.javascript基础学习

    javascript基础学习:   http://www.w3school.com.cn/jsref/index.asp jS的引入方式: 1.行间事件:为某一个具体的元素标签赋予js内容,oncli ...

  5. JavaScript 基础学习(二)js 和 html 的结合方式

    第一种 使用一个标签 <script type="text/javascript"> js代码; </script> 第二种 使用 script 标签,引入 ...

  6. Python基础学习四

    Python基础学习四 1.内置函数 help()函数:用于查看内置函数的用途. help(abs) isinstance()函数:用于判断变量类型. isinstance(x,(int,float) ...

  7. JavaScript 基础 学习 (二)

    JavaScript 基础 学习 节点属性 ​ 每一个节点都有自己的特点 ​ 这个节点属性就记录着属于自己节点的特点 1. nodeType(以一个数字来表示这个节点类型) ​ 语法:节点.nodeT ...

  8. JavaScript 基础 学习 (一)

    JavaScript 基础 学习 获取页面中的元素的方法 作用:通过各种方式获取页面中的元素 ​ 比如:id,类名,标签名,选择器 的方式来获取元素 ​ 伪数组: ​ 长的和数组差不多,也是按照索引排 ...

  9. 几张非常有意义的JavaScript基础学习思维图

    分享几张对于学习JavaScript基础知识非常有意义的图,无论你的JavaScript级别如何,“温故而知新”完全可以从这些图中得到. 推荐理由:归类非常好,非常全面 JavaScript 数组 J ...

随机推荐

  1. 【Spring注解驱动开发】面试官:如何将Service注入到Servlet中?朋友又栽了!!

    写在前面 最近,一位读者出去面试前准备了很久,信心满满的去面试.没想到面试官的一个问题把他难住了.面试官的问题是这样的:如何使用Spring将Service注入到Servlet中呢?这位读者平时也是很 ...

  2. LaTeX常用符号(持续更新)

    参考网址:https://qianwenma.cn/2018/05/17/mathjax-yu-fa-can-kao/# 基本运算 1.乘法$x\times y$ x\times y 2.乘法$x^{ ...

  3. PytorchMNIST(使用Pytorch进行MNIST字符集识别任务)

    都说MNIST相当于机器学习界的Hello World.最近加入实验室,导师给我们安排了一个任务,但是我才刚刚入门呐!!没办法,只能从最基本的学起. Pytorch是一套开源的深度学习张量库.或者我倾 ...

  4. 【K8s学习笔记】K8s是如何部署应用的?

    本文内容 本文致力于介绍K8s一些基础概念与串联部署应用的主体流程,使用Minikube实操 基础架构概念回顾 温故而知新,上一节[K8S学习笔记]初识K8S 及架构组件 我们学习了K8s的发展历史. ...

  5. SQL注入之报错注入常见函数

  6. Codeforces Round #652 (Div. 2) 总结

    A:问正n边形的一条边和x轴平行的时候有没有一条边和y轴重合,直接判断n是否是4的倍数 #include <iostream> #include <cstdio> #inclu ...

  7. pxc搭建mysql集群

    docker -y update yum install -y docker service docker satrt docker images 服务器:curl -sSL https://get. ...

  8. 苹果XR手机的音频体验测试总结

    苹果XR手机的音频   苹果XR算是苹果手机历史上一个里程碑的型号了,是苹果憋了两年的大招,连苹果9的称号就不要了.直接是X.说明苹果对它给予的希望很大.作为一个音频算法工程师,一直想体验一下XR的音 ...

  9. Asp.net Core AOP实现(采用Autofac)

    引用正确的库来实现AOP 新的.NET Core是基于.NET Standard的..所以我们在引用库的时候特别要注意相关的兼容问题. 在传统的ASP.NET中,使用过Autofac来进行AOP操作的 ...

  10. python中的多任务--线程

    什么是多任务? 简单地说,就是操作系统可以同时运行多个任务. 实现多任务有多种方式,线程.进程.协程. 多任务的概念:并行和并发 并发:指的是任务数多余cpu核数,通过操作系统的各种任务调度算法, 实 ...