Bom,事件对象

Bom引入

浏览器对象模型

浏览器就是Bom

打开浏览器,通过浏览器可以打开多个标签页(网页窗口)

一个标签页,对应一个window,即Bom对应多个window(Bom包含window)

Dom是window的一个子对象

学习Bom,主要学习window下除了Dom之外的其他子对象以及属性方法

open方法

作用跳转页面(同超链接)

<!--在当前页面跳转-->
<a href="https://www.baidu.com" target="_self">百度</a>
<div class="d1">百度</div>
<!--在新页面跳转-->
<div class="d2">百度</div>
<!--在新页面跳转且只能打开一个新页面-->
<a href="https://www.baidu.com" target="abc">百度</a>
<div class="d3">百度</div>
<script type="text/javascript">d1.onclick = function () {//跳转到指定位置//默认打开新窗口//餐护士2,跳转方式同超链接的target的属性open('https://www.baidu.com')}d2.onclick = function () {//默认值是"_blank"open('https://www.baidu.com" target="_blank')}d3.onclick = function () {open('https://www.baidu.com" target="abc')}
</script>

event 事件对象

<div class="d1">123</div>
<script type="text/javascript">//旧的绑定事件的方式// d1.onclick = function () {//     alert(123);// }//新的绑定事件的方式// d1.addEventListener('click', function () {//     alert(123);// })//addEventListener方法//第一个参数是事件类型(事件)//第二个参数是事件处理函数(匿名函数或者函数名)//注:不是执行函数,不能加小括号function fn1() {alert(123);}d1.addEventListener('click', fn1);//addEventListener可以给事件追加函数d1.addEventListener('click', function () {alert(456);})//onxx的绑定事件的方式可以追加函数吗?//不能追加,后面会覆盖前面的//移除事件d1.removeEventListener('click', fn1);//removeEventListener方法//第一个参数是事件类型(事件)//第二个参数是要移除的函数名//注:能够移除的函数,只能是在绑定时用函数名的方式绑定,如果用匿名函数的方式绑定,则没办法移除//比如本例中,弹框输出456的函数就没办法移除</script>

小结:1.绑定一些简单的事件,后续不会有(追加+移除),事件委托等高级需求,则优先使用onxx的方式绑定

2.使用addEventListener绑定事件时,优先使用方法名的方式绑定

<div id="d5"><div id="d4"><div id="d3"><div id="d2"><div id="d1"></div></div></div></div>
</div>
<script type="text/javascript">//addEventListener的第三个参数d1.addEventListener('click', function () {alert(1)},true);d2.addEventListener('click', function () {alert(2)},true);d3.addEventListener('click', function () {alert(3)},true);d4.addEventListener('click', function () {alert(4)},true);d5.addEventListener('click', function () {alert(5)},true);//冒泡与捕获,就是当同时触发多个元素的同一个事件时,所触发的执行顺序//冒泡:从最内层的元素开始,依次向外层元素执行//捕获:从最外层的元素开始,依次向内层元素执行//默认是冒泡,如果设置为true,则是捕获
</script>

分析:

当挺好四触发多个元素的同一个事件时,就会存在两个阶段

即捕获阶段与冒泡阶段

按照先捕获后冒泡的顺序执行方法

通过addEventListener的第三个参数来控制当前事件处于哪个阶段

然后按照先捕获后冒泡的顺序执行方法

同一个阶段的事件按照阶段的特点来确定顺序

捕获阶段的事件按照由外到内的顺序来执行

冒泡阶段的事件按照由内到外的顺序来执行

事件对象

如何获取事件对象?

注:只有事件触发的函数才有事件对象,普通方法没有事件对象

<div id="d1">123</div>
<script type="text/javascript">d1.onclick=function (e) {//事件触发的方法//event关键字就是事件对象console.log(event);//默认参数就是事件对象console.log(e);}function fn(e){//普通方法内没有事件对象console.log(e);console.log(event)}fn()//undefined//直接调用就是普通方法d1.ondblclick=fn//由事件触发就可以获取事件对象
</script>
<div id="d5"><div id="d4"><div id="d3"><div id="d2"><div id="d1"></div></div></div></div>
</div>
<script type="text/javascript">//事件对象//功能1:停止后续方法,//注:如果停止的是不会阶段的方法,那么冒泡阶段的事件就会全军覆没//功能2:获取最里面的元素//注:获取的是所有触发事件里面的元素中,最里面的元素d1.addEventListener('click', function () {alert(1)},true);d2.addEventListener('click', function () {alert(2)},true);d3.addEventListener('click', function () {alert(3)},true);d4.addEventListener('click', function () {event.stopPropagation();//停止后续方法alert(4)},true);d5.addEventListener('click', function () {alert(5)console.log(event.target)//获取最里面的元素},true);
</script>

事件委托

当具有相同父元素的元素要绑定相同的事件,且触发的方式也相同,则可以考虑事件委托

<ul class="uu"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li>
</ul>
<script !src="">let uu = document.querySelector('.uu');uu.onclick = function (e) {//通过event.target获取到最里面的元素console.log(e.target);//判断点击的最里面元素是不是liif(e.target.nodeName === 'LI'){//点击到li输出内容console.log(e.target.innerHTML);}}
</script>

事件委托,把要触发的方法绑定给父元素

通过event.target来判断子元素是否触发了事件

如果触发了事件,则在事件内通过event.target来代表触发事件的子元素

默认方法

HTML固有方法就是默认方法,比如超链接的跳转功能

通过事件停止默认方法

<a href="https://www.cnblogs.com/xiaohuochai/p/8444357.html">ha</a>
<script src="">let a=document.querySelector('a');a.onclick=function (e) {alert(1);e.preventDefault();//停止默认方法}
</script>

注:需要在触发默认方法的实际那种停止默认方法

window的其他子对象

history浏览记录

<button id="btn1">后退</button>
<button id="btn2">刷新</button>
<button id="btn3">前进</button>
<script !src="">// history.go()方法//go(0)刷新//go(1)前进,跳转到点击后退按钮到当前页面的页面//go(-1)后退document.getElementById("btn1").onclick = function () {history.go(-1);}document.getElementById("btn2").onclick = function () {history.go(0);}document.getElementById("btn3").onclick = function () {history.go(1);}
</script>

location

<button id="btn1">assign</button>
<button id="btn2">reload</button>
<button id="btn3">replace</button>
<script !src="">//hash:路径中的哈希部分(#及后面的部分)//host:主机名+端口号//hostname:主机名//href:完整路径//origin:协议+主机名+端口号//pathname:路径//port:端口号//protocol:协议//search:通过路径明文传递的数据btn1.onclick = function () {//正常跳转location.assign('https://www.baidu.com')}btn2.onclick = function () {//刷新location.reload()}btn3.onclick = function () {//跳转并且清除跳转前页面的记录location.replace('https://www.baidu.com')}
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/767049.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端制作计算器

用htmlcssjs完成计算器的基本功能&#xff0c;代码如下&#xff1a; HTML代码 <div id"four"> <div class"evaluator"><div class"input"><input type"text"></div><table><tr><td>…

谧林涓露门禁

原神武器升级材料谧林涓露和门禁好像聂。 difference(){union(){cylinder(2, 10,10, $fn365);hull(){translate([15,0,0])cylinder(1,2,2,$fn365);cylinder(1,10,10,$fn365);}}translate([15,0,-1])cylinder(4,1,1,$fn365); }

modelsim与quartus联合仿真ROM读不出数据

modelsim与quartus联合仿真ROM没有数据被读出&#xff0c;很是纳闷。 原因&#xff1a;hex或者mif文件放的不对&#xff0c;放在与db放在同一个文件夹下。modelsim在这个目录查找mif文件或hex。 这是我遇到的问题。当然可能还有其他的问题&#xff1a; 1、mif文件的格式不对&a…

platform devices创建实例

来看一个cortina Gemini ethernet driver的例子。 DTS file路径 /arch/arm/boot/dts/gemini/gemini.dtsi. Driver 路径 drivers/net/ethernet/cortina/gemini.c {soc {#address-cells <1>;#size-cells <1>;ranges;compatible "simple-bus";....ethe…

双系统安装03--在已有麒麟KOS基础上安装Windows10

原文链接&#xff1a;双系统安装03–在已有麒麟KOS基础上安装Windows10 Hello&#xff0c;大家好啊&#xff01;继我们之前讨论的关于双系统安装的系列文章之后&#xff0c;今天我将带给大家这个系列的第三篇——在已有的麒麟桌面操作系统上安装Windows 10。对于想要在使用麒麟…

OpenCV支持哪些类型的文件格式读写?

OpenCV支持多种类型的文件格式读写&#xff0c;包括但不限于以下格式&#xff1a; Windows位图文件&#xff1a;包括BMP和DIB格式。JPEG文件&#xff1a;支持JPEG、JPG和JPE三种扩展名。便携式网络图片&#xff1a;即PNG格式。便携式图像格式&#xff1a;包括PBM、PGM和PPM三种…

Kafka系列之:Exactly-once support

Kafka系列之:Exactly-once support 一、Sink connectors二、Source connectors三、Worker configuration四、ACL requirementsKafka Connect 能够为接收器连接器(从版本 0.11.0 开始)和源连接器(从版本 3.3.0 开始)提供一次性语义。请注意,对一次语义的支持高度依赖于您运…

关于Mysql表中使用‘utf8mb4_unicode_ci’字符集问题

业务场景&#xff1a;需求点项目excel数据导入&#xff0c;会对重复名称校验拦截&#xff0c;如&#xff1a;之前已插入名称为-半角括号“&#xff08;a&#xff09;”,再次插入一条名称为-全角括号项目“(a)”,校验通过&#xff0c;但是插入数据库报错。 原因&#xff1a;由于…

docker安装ES7.1.1(单机版)+ik分词器+es-head可视化

系列文章目录 文章目录 系列文章目录前言 前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站&#xff0c;这篇文章男女通用&#xff0c;看懂了就去分享给你的码吧。 Elasticsearch 是一…

力扣236 二叉树的最近公共祖先 Java版本

文章目录 题目描述代码 题目描述 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点 p、q&#xff0c;最近公共祖先表示为一个节点 x&#xff0c;满足 x 是 p、q 的祖先且 x 的深度尽可能大&…

滑动窗口(尺取法)

滑动窗口&#xff08;尺取法&#xff09; 算法含义&#xff1a; 在解决关于区间特性的题目时保存搜索区间左右端点&#xff0c;然后根据实际要求不断更新左右端点位置的算法 时间复杂度&#xff1a; O ( n ) O(n) O(n) 空间复杂度&#xff1a; O ( 1 ) O(1) O(1) 在历年真题…

【React】在 JSX 中通过大括号使用 JavaScript

在 JSX 中使用大括号可以执行各种 JavaScript 操作&#xff0c;包括传递字符串、引用变量、调用函数以及使用对象。下面是一些具体的例子&#xff1a; 使用引号传递字符串 在 JSX 中&#xff0c;如果你想直接输出一个字符串&#xff0c;你可以直接在花括号内使用双引号或单引…

FlyControls 是 THREE.js 中用于实现飞行控制的类,它用于控制摄像机在三维空间中的飞行。

demo演示地址 FlyControls 是 THREE.js 中用于实现飞行控制的类&#xff0c;它用于控制摄像机在三维空间中的飞行。 入参&#xff1a; object&#xff1a;摄像机对象&#xff0c;即要控制的摄像机。domElement&#xff1a;用于接收用户输入事件的 HTML 元素&#xff0c;通常…

C++函数参数传递

目录 传值参数 指针形参 传引用参数 使用引用避免拷贝 使用引用形参返回额外信息 const形参和实参 指针或引用形参与const 数组形参 管理指针形参 使用标记指定数组长度 使用标准库规范 显式传递一个表示数组大小的形参 数组形参和const 数组引用形参 传递多维数…

Django缓存(一)

一、缓存的介绍 官网:Django 缓存框架 | Django 文档 | Django 为什么要什么缓存? 为了减少服务器的计算开销 Django框架自带有一个强大的缓存系统,可以保存动态页面,因此不必为每个请求计算它们。为了方便,Django提供不同级别的缓存粒度:可以缓存特定视图的输出,可以只…

Web核心简介

简介 web&#xff1a;全球广域网&#xff0c;也称万维网(www)&#xff0c;能够通过浏览器访问的网站 JavaWeb&#xff1a;是用Java技术来解决相关web互联网领域的技术栈 JavaWeb技术栈 B/S架构&#xff1a;Browser/Server&#xff0c;浏览器/服务器架构模式&#xff0c;它的…

走迷宫----bfs再矩阵图里的应用模版

对于之前走迷宫的那个题 回忆一下dfs的代码 #include <bits/stdc.h> using namespace std; int a[110][110]; bool check[110][110]; int n,m; int ans1e9; int nxt[4][2]{{1,0},{0,-1},{-1,0},{0,1}}; void dfs(int x,int y,int step){if(xn&&ym){ansmin(ans,…

IntelliJ IDEA集成git配置账号密码

1 背景说明 刚使用IDEA,本地也安装Git,在提交和拉取代码的时候,总提示登录框,而且登录框还不能输入账号密码,只能输入登录Token。如下: 从而无法正常使用IDEA的Git功能,很苦恼。 2 解决方法 2.1 安装Git 进入官网地址 https://git-scm.com/,点击下载: 浏览器直接…

python中的IO流及其对象序列化

IO流input output stream的缩写 侠义&#xff1a;常见的IO操作是指内存与磁盘之间的输入和输出的操作 io流的操作是一种持久化操作。将数据持久化到磁盘上 open全局函数&#xff1a; 第一个参数file&#xff1a;代表的是打开或者操作的文件的文件名或者路径 第二个参数mod…

机器学习算法那些事 | 使用Transformer模型进行时间序列预测实战

本文来源公众号“机器学习算法那些事”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;使用Transformer模型进行时间序列预测实战 时间序列预测是一个经久不衰的主题&#xff0c;受自然语言处理领域的成功启发&#xff0c;transfo…