【JavaScript】延迟加载 js 脚本

  1. defer 属性:在 HTML 中通过设置 script 标签的 defer 属性来实现脚本的延迟加载,即脚本的下载与 HTML 的解析不会阻塞彼此,脚本会在 HTML 解析完成后才执⾏。
  2. async 属性:在 HTML 中通过设置 script 标签的 async 属性来实现脚本的异步加载,即脚本的下载与 HTML 的解析不会阻塞彼此,脚本下载完成后会⽴即执⾏,但脚本执⾏时可能会阻塞 HTML 解析。<script src="test.js" async></script>
  3. 动态加载脚本:通过 JavaScript 动态创建 script 标签,并设置其 src 属性来实现脚本的异步加载,这种⽅式需要在脚本加载完成后⼿动执⾏脚本。
var script = document.createElement('script');
script.src = 'test.js';
document.body.appendChild(script);
  1. 懒加载模式:在需要时再加载脚本,可以使⽤ jQuery 等库实现,或者通过⾃⼰编写的函数来实现。
  2. 让 JS 最后加载:将 <script> 放在⻚⾯内容的底部(即</body>前),也就是让浏览器从上到下解析完 HTML 后再加载 JS 脚本⽂件,从⽽起到延迟加载的作⽤。
  3. 使⽤ Intersectionobserver API:可以在元素进⼊视窗时再加载脚本,实现延迟加载。
var observer = new IntersectionObserver(function (entries) {if (entries[0].isIntersecting) {var script = document.createElement("script");script.src = "test.js";document.body.appendChild(script);}},{ threshold: 0.5 }
);
var target = document.querySelector("#target");
observer.observe(target);
  1. setTimeout :设置⼀个定时器来延迟加载 JS 脚本⽂件。但是不好控制时间,不推荐使用。如果时间设置过⻓,会延迟⻚⾯的加载速度;如果时间设置过短,可能会在⻚⾯还没有完全加载完成时执⾏脚本,导致错误。

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

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

相关文章

【论文共读】【翻译】ShuffleNet v1:一种用于移动设备的极其高效的卷积神经网络

[原文地址] https://arxiv.org/pdf/1707.01083 [翻译] 0. 摘要 我们介绍了一种计算效率极高的CNN架构&#xff0c;称为ShuffleNet&#xff0c;该架构专为计算能力非常有限的移动设备&#xff08;例如&#xff0c;10-150 MFLOPs&#xff09;而设计。新架构利用了两个新操作&am…

Ubuntu 22.04.4 LTS (linux) Tomcat 下载 安装配置详细教程

1 官网下载 下载链接 2 ubuntu 服务器安装 #下载 wget https://dlcdn.apache.org/tomcat/tomcat-9/v9.0.91/bin/apache-tomcat-9.0.91.tar.gz #解压 tar zxvf apache-tomcat-9.0.91.tar.gz sudo mv apache-tomcat-9.0.91/ /data/tomcat #配置环境变量 sudo vi /etc/profil…

WebGoC题解(13) 狐猬编程:GoC L4 结业测试 第4题 找木柴

题目描述 小明今天找了n跟木柴&#xff0c;但是木柴太多了&#xff0c;小明只能拿走m根木柴&#xff0c;小明希望拿走的木柴都是剩下的木柴中最长的&#xff0c;小明还画出以下图形 例如 输入 5 3 10 20 30 40 50 小明要拿走30 40 50 这3根木柴 从大到小画出以下图形 矩形的宽…

linux cpu 占用超100% 分析。

感谢: https://www.cnblogs.com/wolfstark/p/16450131.html 总结&#xff1a; 查看进程中各个线程占用百分比 top -H -p <pid> 某线程100%了 说明 任务处理不过来 会卡 但是永远不可能超100% 系统监视器里面看到的是 所有线程占用的 总和会超100%。 所以最好的情况是&…

Android DataBinding从入门到精通

DataBinding可以更加方便的编写与视图交互的代码。即系统会为模块中的每个xml文件生成一个绑定类&#xff0c;其实例包含指向相应布局中具有ID的所有视图的直接引用。大多数情况下&#xff0c;DataBinding会代替findMyId。 启动DataBinding 在Android SDK 32及后续版本中&…

如祺出行大跌:现在谈Robotaxi概念股是不是太早了?

文&#xff1a;互联网江湖 作者&#xff1a;刘致呈 有人说Robotaxi就像当年汽车换马车&#xff0c;是生产力的进步&#xff0c;是历史的更迭。 真的如此吗&#xff1f; 人们有疑问&#xff0c;市场也有疑问。 你看市面上主打Robotaxi概念的企业&#xff0c;有几家是持续向好…

MATLAB基础:字符串、元胞数组

今天我们继续学习MATLAB中的字符串、元胞和结构 字符串 由于MATLAB是面向矩阵的&#xff0c;所以字符串的处理可以用矩阵的形式实现 字符串的赋值与引用 假设变量a&#xff0c;将用单引号引起来的字符串赋值给它&#xff0c; a清心明目, b(a[4;-1;1]) 在这里&#xff0c;…

如何检查我的网站是否支持HTTPS

HTTPS是一种用于安全通信的协议&#xff0c;是HTTP的安全版本。HTTPS的主要作用在于为互联网上的数据传输提供安全性和隐私保护。通常是需要在网站安装部署SSL证书来实现网络数据加密传输&#xff0c;安全加密功能。 那么如果要检查你的网站是否支持HTTPS&#xff0c;可以看下…

云计算实训11——web服务器的搭建、nfs服务器的搭建、备份静态文件、基于linux和windows实现文件共享

一、搭建web服务器 1.关闭firewall和selinux 关闭防火墙 systemctl stop firewalld systemctl disable firewalld 停用selinux setenforce 0 配置文件中让sellinux不再启动 vim /etc/selinux/config SELINUXpermissive 2.编辑dns配置文件 vim /etc/resolv.conf nameserver 114.…

Go基础编程 - 11 - 函数(func)

接口&#xff08;interface&#xff09; 函数1. 函数定义1.1. 函数名1.2. 参数列表1.3. 返回值列表 2. 匿名函数3. 闭包、递归3.1 闭包3.1.1 函数、引用环境3.1.2 闭包的延迟绑定3.1.3 goroutine 的延迟绑定 3.2 递归函数 4. 延迟调用&#xff08;defer&#xff09;4.1 defer特…

个性化IT服务探索实践

探索和实践个性化IT服务,可以为用户提供更优质、定制化的解决方案,从而提升用户体验和满意度。以下是一些具体的步骤和建议,帮助自己在未来探索和实践个性化IT服务。 一、了解用户需求 用户调研和反馈: 进行用户调研,了解用户的需求和痛点。收集用户反馈,通过问卷、采访…

逆向破解 对汇编的 简单思考

逆向破解汇编非常之简单 只是一些反逆向技术非常让人难受 但网络里都有方法破解 申请变量 &#xff1a; int a 0; 00007FF645D617FB mov dword ptr [a],0 char b b; 00007FF645D61802 mov byte ptr [b],62h double c 0.345; 00007FF645D61…

2024-07-22 Unity AI行为树1 —— 框架介绍

文章目录 1 行为树2 行为树驱动方式3 行为树结点分类3.1 控制节点3.2 执行节点 4 行为树与状态机比较 本文章参考 B 站唐老狮 2023年直播内容。 点击前往唐老狮 B 站主页。 1 行为树 ​ 行为树&#xff08;Behavior Tree&#xff0c;BT&#xff09;在游戏 AI 中是一种用于控制…

微软蓝屏事件:网络安全与系统稳定性的反思与前瞻

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

探索深度学习在图像识别领域的创新应用

摘要&#xff1a; 本文深入探讨了深度学习在图像识别领域的最新进展和创新应用。通过对卷积神经网络&#xff08;CNN&#xff09;等模型的研究&#xff0c;分析了其在人脸识别、物体检测和场景理解等方面的卓越表现&#xff0c;并展望了未来深度学习技术在图像识别领域的发展趋…

javascript 的执行上下文与作用域

目录 1. 初步了解 上下文&#xff08;context&#xff09;2. 全局上下文(global context)3. 上下文栈 (context stack)4. 作用域链( scope chain)5. 作用域(scope)6. 作用域链增强7. 变量声明7.1 var 声明变量7.2 let 声明变量7.3 const 常量声明 1. 初步了解 上下文&#xff0…

React前端面试每日一试 2.JSX是什么?JSX如何工作?

JSX是什么&#xff1f; JSX&#xff08;JavaScript XML&#xff09;是React引入的一种语法扩展&#xff0c;用于在JavaScript中编写类似HTML的结构。它让我们能够直观地描述UI的结构&#xff0c;同时保留JavaScript的编程能力。尽管JSX看起来像HTML&#xff0c;但它最终会被编…

轨迹优化 | 基于ESDF的共轭梯度优化算法(附ROS C++/Python仿真)

目录 0 专栏介绍1 数值优化&#xff1a;共轭梯度法2 基于共轭梯度法的轨迹优化2.1 障碍约束函数2.2 曲率约束函数2.3 平滑约束函数 3 算法仿真3.1 ROS C实现3.2 Python实现 0 专栏介绍 &#x1f525;课程设计、毕业设计、创新竞赛、学术研究必备&#xff01;本专栏涉及更高阶的…

Unity3D UGUI适配不同分辨率详解

前言 在Unity3D开发中&#xff0c;UGUI&#xff08;Unitys Graphical User Interface&#xff09;是构建用户界面&#xff08;UI&#xff09;的重要工具。然而&#xff0c;随着移动设备和桌面设备的分辨率日益多样化&#xff0c;确保UI能够在不同分辨率下良好显示变得尤为重要…

CAS乐观锁原理

1、什么是CAS&#xff1f; compare and swap也就是比较和交换&#xff0c;他是一条CPU的并发原语。 他在替换内存的某个位置的值时&#xff0c;首先查看内存中的值与预期值是否一致&#xff0c;如果一致&#xff0c;执行替换操作。 这个操作是一个原子性操作。 Java中基于Un…