JavaScript资源加载:onload,onerror

🧑‍🎓 个人主页:《爱蹦跶的大A阿》

🔥当前正在更新专栏:《VUE》 、《JavaScript保姆级教程》、《krpano》、《krpano中文文档》

​ 

✨ 前言

资源加载 是 web 开发中的一个重要概念,指的是浏览器加载资源(例如图像、脚本、样式表等)的过程。在这个过程中,会发生一系列事件,其中 onloadonerror 两个事件是重要的里程碑。

onload 事件 发生在资源加载成功之后。此时,资源可以使用了。

onerror 事件 发生在资源加载失败之后。此时,可以显示错误信息或采取其他措施。

理解 onload 和 onerror 事件 的区别和应用场景,对于开发人员来说至关重要。本文将深入探讨这两个事件,并提供大量代码示例,帮助你:

  • 掌握 onload 和 onerror 事件的触发时机
  • 了解如何使用这两个事件来实现不同的功能
  • 学习如何阻止事件传播
  • 掌握如何使用相关属性

无论你是初学者还是经验丰富的开发人员,本文都将为你提供一些有价值的信息。

在阅读本文之前,请确保你已经具备以下基础知识:

  • HTML 基础
  • JavaScript 基础

准备好了吗?让我们开始吧!

✨ 正文

简介

当浏览器加载资源(例如图像、脚本、样式表等)时,会发生一系列事件。其中,onloadonerror 两个事件用于检测资源加载是否成功。

onload 事件

当资源加载成功时,会触发 onload 事件。

onerror 事件

当资源加载失败时,会触发 onerror 事件。

事件处理程序

可以使用 addEventListener() 方法为元素添加 onloadonerror 事件处理程序。

代码示例

// 为图像添加 onload 事件处理程序
document.getElementById("image").addEventListener("onload", function() {// 图像加载成功
});// 为脚本添加 onerror 事件处理程序
document.getElementById("script").addEventListener("onerror", function() {// 脚本加载失败
});

阻止事件传播

可以使用 stopPropagation() 方法阻止事件传播。

代码示例

document.getElementById("image").addEventListener("onload", function(event) {event.stopPropagation();// 图像加载成功
});

相关属性

  • readyState:用于指示资源的加载状态。

更多信息

  • Window.onload Event: Window: load event - Web APIs | MDN
  • Error Event: ErrorEvent - Web APIs | MDN

代码示例

使用 onload 事件显示图像

<img id="image" src="image.jpg"><script>
document.getElementById("image").addEventListener("onload", function() {document.getElementById("image").style.display = "block";
});
</script>

使用 onerror 事件显示错误信息

<script id="script" src="script.js"></script><script>
document.getElementById("script").addEventListener("onerror", function() {alert("An error occurred while loading the script");
});
</script>

使用 onload 和 onerror 事件进行验证

<form action="/action_page.php"><input type="text" name="name" id="name"><input type="submit" value="Submit">
</form><script>
document.getElementById("name").addEventListener("focus", function() {if (name === "") {alert("Please enter your name");return false;}
});document.getElementById("form").addEventListener("submit", function(event) {event.preventDefault();const formData = new FormData(document.getElementById("form"));// 这里处理表单数据// 提交表单document.getElementById("form").submit();
});
</script>

 

 

✨ 结语

        onloadonerror 两个事件是重要的资源加载事件,用于检测资源加载是否成功。它们可以用于各种目的,例如显示图像、显示错误信息、进行验证等等。

希望本文对你有所帮助!

以下是一些额外的建议:

  • 阅读 HTML 和 JavaScript 文档,以了解更多关于 onload 和 onerror 事件的信息。
  • 练习使用 onload 和 onerror 事件来实现不同的功能。
  • 在实际项目中使用 onload 和 onerror 事件。

祝你学习愉快!

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

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

相关文章

【EAI 020】Diffusion Policy: Visuomotor Policy Learning via Action Diffusion

论文标题&#xff1a;Diffusion Policy: Visuomotor Policy Learning via Action Diffusion 论文作者&#xff1a;Cheng Chi, Siyuan Feng, Yilun Du, Zhenjia Xu, Eric Cousineau, Benjamin Burchfiel, Shuran Song 作者单位&#xff1a;Columbia University, Toyota Research…

第4讲 小程序首页实现

首页 create.vue <template><view class"vote_type"><view class"vote_tip_wrap"><text class"type_tip">请选择投票类型</text><!-- <text class"share">&#xe739;分享给朋友</text&g…

98.网游逆向分析与插件开发-网络通信封包解析-定位明文发送数据的关键函数

内容参考于&#xff1a;易道云信息技术研究院VIP课 上一个内容&#xff1a;项目需求与需求拆解 通过上一个内容有了对网络通信架构有一个简单认识了解&#xff0c;对于我们重要的点是 组织数据 到 加密数据之间的过程&#xff0c;这个过程的数据我们是可以看懂的&#xff0c;…

笔记---dp---最长上升子序列模型

模型原始题目&#xff1a;AcWing.895.最长上升子序列 题目关系如下&#xff1a; 转化一 AcWing.1017.怪盗基德的滑翔翼 怪盗基德是一个充满传奇色彩的怪盗&#xff0c;专门以珠宝为目标的超级盗窃犯。 而他最为突出的地方&#xff0c;就是他每次都能逃脱中村警部的重重围堵…

Vue核心基础1:数据代理

1 回顾Object.defineProperty方法 let str hello const person {name: 张三,age: 18 } Object.defineProperty(person, sex, {// value: 男,// enumerable: true, // 控制属性是否可以枚举&#xff0c;默认值是false// writable: true, // 控制属性是否可以被修改&#xff0…

C++进阶(十四)智能指针

&#x1f4d8;北尘_&#xff1a;个人主页 &#x1f30e;个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上&#xff0c;不忘来时的初心 文章目录 一、为什么需要智能指针&#xff1f;二、内存泄漏1、 什么是内存泄漏&#xff0c;内存泄漏的危…

Vulnhub靶机:hacksudo-ProximaCentauri

一、介绍 运行环境&#xff1a;Virtualbox 攻击机&#xff1a;kali&#xff08;10.0.2.15&#xff09; 靶机&#xff1a;hacksudo-ProximaCentauri&#xff08;10.0.2.51&#xff09; 目标&#xff1a;获取靶机root权限和flag 靶机下载地址&#xff1a;https://www.vulnhu…

当AGI遇到人形机器人

为什么人类对人形机器人抱有执念 人形机器人是一种模仿人类外形和行为的机器人&#xff0c;它的研究和开发有着多方面的目的和意义。 人形机器人可以更好地适应人类的环境和工具。人类的生活和工作空间都是根据人的尺寸和动作来设计的&#xff0c;例如门、楼梯、桌椅、开关等…

再利用系统盘时,如何删除恢复分区(Recovery Partition)

系统盘有一个Recovery Partition&#xff0c;记录了重要的系统信息&#xff0c;不能删除。 Windows 10的 Disk Managment 不提供用户删除这个Partition的选项。 近日我插入一块原系统盘&#xff0c;Format后作为DataDisk&#xff0c;此时需要删除这块硬盘上的RecoveryPartition…

交叉熵损失函数(Cross-Entropy Loss)的基本概念与程序代码

交叉熵损失函数&#xff08;Cross-Entropy Loss&#xff09;是机器学习和深度学习中常用的损失函数之一&#xff0c;用于分类问题。其基本概念如下&#xff1a; 1. 基本解释&#xff1a; 交叉熵损失函数衡量了模型预测的概率分布与真实概率分布之间的差异。在分类问题中&…

C语言每日一题(55)另一颗树的子树

力扣 572 另一棵树的子树 题目描述 给你两棵二叉树 root 和 subRoot 。检验 root 中是否包含和 subRoot 具有相同结构和节点值的子树。如果存在&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 二叉树 tree 的一棵子树包括 tree 的某个节点和这个节点的所…

Stable Diffusion 模型下载:majicMIX lux 麦橘辉耀 - V3

本文收录于《AI绘画从入门到精通》专栏,专栏总目录:点这里。 文章目录 模型介绍生成案例案例一案例二案例三案例四案例五案例六案例七案例八案例九案例十