JavaScript高级程序设计 阅读笔记(十七) js事件

yizhihongxing

JavaScript是一种基于对象和事件驱动的编程语言,可以实现页面的互动效果。在JavaScript高级程序设计中,js事件的相关知识是常见的知识点。本篇笔记主要介绍js事件的相关内容。

事件的概述

在Web应用中,经常需要处理用户的输入或操作,例如,鼠标单击、按键按下等操作。这种操作可以称之为事件,事件可以被JavaScript代码监听并进行相应的处理,从而实现页面的互动效果。

事件处理程序

为了监听和处理事件,JavaScript提供了事件处理程序。事件处理程序可以是函数或是函数表达式,可以通过HTML元素的属性来指定,例如:

<button onclick="alert('Hello')">点击</button>

上述代码中,按钮元素的onclick属性会在按钮被点击时执行alert('Hello')语句。

另外,也可以通过JavaScript代码来为元素添加事件处理程序,例如:

var btn = document.querySelector('button');
btn.onclick = function() {
    alert('Hello');
};

上述代码中,querySelector方法获取了第一个button元素,然后为按钮元素的onclick属性赋值一个函数表达式,函数表达式实现了弹出Hello的效果。

事件模型

JavaScript事件模型分为两种:DOM0级事件和DOM2级事件。DOM0级事件是指通过HTML元素的属性来指定事件处理程序,例如上面示例中的按钮的onclick属性。DOM2级事件是指通过addEventListener()和removeEventListener()方法来实现事件处理程序的添加和删除。

这两种事件模型的主要区别在于多个事件处理程序的执行顺序。在DOM0级事件中,同一事件只能指定一个事件处理程序。在DOM2级事件中,一个元素可以为同一事件指定多个事件处理程序,多个事件处理程序的执行顺序由添加的顺序决定。

事件流

事件流描述的是事件从页面中接收的顺序,事件可以沿着两个方向流动:从文档顶部向下流动(捕获阶段)和从文档底部向上流动(冒泡阶段)。

当HTML元素嵌套时,事件的流动会按照HTML元素的嵌套结构依次触发,先从祖先元素开始触发,再依次向下触发。

<div id="outer">
    <div id="inner">点击这里</div>
</div>
var outer = document.querySelector('#outer');
var inner = document.querySelector('#inner');

outer.addEventListener('click', function() {
    console.log('outer');
}, true);
inner.addEventListener('click', function() {
    console.log('inner');
}, true);

上述代码中,在outer元素和inner元素都添加了事件处理程序,第三个参数设置为true,则事件处于捕获阶段。这时,点击inner元素,会先触发outer元素的事件处理程序,然后再触发inner元素的事件处理程序。

阻止事件冒泡和默认行为

在事件冒泡过程中,除非阻止事件冒泡,否则事件会一直冒泡到document对象,可以使用stopPropagation()方法来阻止事件冒泡。

另外,有些元素在默认情况下会执行一些操作,例如在表单中提交表单数据时,可以使用preventDefault()方法来阻止元素默认行为的执行。

<a href="https://www.baidu.com/">百度一下</a>
var a = document.querySelector('a');
a.addEventListener('click', function(event) {
    event.preventDefault();
}, false);

上述代码中,在点击a元素时,将会阻止默认行为,不会打开新的页面。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript高级程序设计 阅读笔记(十七) js事件 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • JavaScript实现cookie的操作

    下面是详细讲解 JavaScript 实现 Cookie 操作的攻略。 什么是 Cookie Cookie(中文翻译为“网页 Cookie”或者“浏览器 Cookie”)是网站为了辨别用户身份的一种标识,是存在用户本地终端上的数据。Cookie 是小型文本文件,由网站服务器发送给用户浏览器,浏览器会将其存储在本地,之后每次请求该网站时都会携带该 Cookie…

    JavaScript 2023年6月11日
    00
  • 实例学习Javascript之构建方法、属性

    关于”实例学习Javascript之构建方法、属性”的攻略分享,可以分为以下几个部分来介绍。 什么是构建方法、属性 在JavaScript中,我们通常使用构造函数来创建对象,构造函数中的方法和属性也被称之为构建方法和构建属性。构建方法和属性是指通过构造函数创建出来的对象所具备的一些方法和属性。 如何定义构建方法、属性 通过定义构造函数,我们可以定义出一些构建…

    JavaScript 2023年5月18日
    00
  • JavaScript常见JSON操作实例分析

    JavaScript常见JSON操作实例分析 本篇文章将介绍JavaScript中常用的JSON操作,包括JSON对象的创建、解析、修改等操作,并提供了多个实例来说明这些操作的使用场景。 JSON对象的创建 使用JavaScript中的JSON对象可以方便地创建和操作JSON格式的数据。要创建JSON对象,可以使用JSON.parse()函数解析一个包含JS…

    JavaScript 2023年6月10日
    00
  • 将编码从GB2312转成UTF-8的方法汇总(从前台、程序、数据库)

    将编码从GB2312转成UTF-8需要从前台、程序和数据库三个方面入手进行相应的转换。 从前台转换 修改HTML文件的编码格式 在HTML文件的head中的meta标签中设置charset为UTF-8,例如: <head> <meta http-equiv="Content-Type" content="tex…

    JavaScript 2023年6月11日
    00
  • JS 强制设为首页的代码

    下面是几个步骤和示例说明: 步骤一:创建按钮 我们要先创建一个按钮,这个按钮会放置在网站的适当位置,用于点击后触发设为首页的功能。可以使用HTML的标签和CSS样式来创建按钮,如下所示: <a href="#" id="setHomePage">设为首页</a> 上述代码中,我们创建了一个id为…

    JavaScript 2023年6月11日
    00
  • JavaScript Window窗口对象属性和使用方法

    JavaScript Window窗口对象属性和使用方法 JavaScript中的Window对象是浏览器窗口的根对象,可以通过Window对象来获取和操作窗口的各种属性和方法。 获取窗口属性 Window.innerHeight和Window.innerWidth属性 Window.innerHeight属性和Window.innerWidth属性分别用于…

    JavaScript 2023年5月27日
    00
  • JavaScript中创建字典对象(dictionary)实例

    要在 JavaScript 中创建一个字典实例,可以使用 JavaScript 内置的对象类型之一:Object。Object 对象是一个通用的对象类型,它可以表示任何一个 JavaScript 对象,包括字典。 创建字典实例 创建一个空的字典实例,可以直接使用 Object 构造函数或对象字面量语法,例如: // 使用 Object 构造函数 const …

    JavaScript 2023年5月27日
    00
  • 实现非常简单的js双向数据绑定

    实现简单的双向数据绑定,主要需要掌握以下两个知识点: 如何监听输入框的变化事件并更新数据模型 如何监听数据模型的变化并更新对应的HTML元素 下面我们分别介绍这两个知识点的实现方法,以及两个示例说明。 监听输入框变化事件 在HTML中,输入框的值可以通过value属性获取到。我们可以使用EventTarget.addEventListener()方法来监听输…

    JavaScript 2023年6月10日
    00
合作推广
合作推广
分享本页
返回顶部