JS 的异步加载方法: async、defer、动态加载

2024-03-22 04:12

本文主要是介绍JS 的异步加载方法: async、defer、动态加载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • JS 的异步加载方法: async、defer、动态加载
    • JS异步加载
      • defer
      • async
      • defer与async对比
      • 动态加载
    • window.onload 与 DOMContentLoaded

JS 的异步加载方法: async、defer、动态加载

JS异步加载

一般写法里 script 脚本会阻塞 HTML 的 DOM 构建,会影响页面渲染,导致白屏时间长等问题。
(优化之一:将 JS 脚本放在 body 最下面,这样能确保脚本能访问一个完整 DOM 树,也不会阻止页面的渲染。)

defer

defer:<script defer src="xx.js"></script>
带有 defer 属性的 JS 脚本不会阻塞 DOM 树的构建,会先加载资源,但执行要等到所有文档元素解析完成后,DOMContentLoaded事件前完成。开发中可以将 defer 脚本放到 head 标签下。

async

async:<script async src="xx.js"></script>
带有 async 属性的 JS 脚本也不会阻塞,也会先加载资源,不同点在于它会在下载完成后立刻执行。

defer与async对比

相同点:都不会阻塞后续元素渲染,都会立刻加载。都只适用于外部脚本。
不同点:async 脚本加载完后会立刻执行,defer 的会在文档元素加载完后,DOMContentLoaded事件前执行。所以需要对DOM元素进行操作的脚本就不应该用async,因为元素可能没加载出来。

动态加载

一般会放在 onLoad 里加载,以避免阻塞页面渲染,并确保页面内容加载完整:

function addScript(src) {var script = document.createElement('script');script.setAttribute('type', 'text/javascript');script.src = src;document.body.appendChild(script);
}
window.onload = function() {addScript('xx.js');
}// 也可以在 DOMContentLoaded 事件中执行动态加载操作
document.addEventListener('DOMContentLoaded', function() {addScript('xx.js');
});

window.onload 与 DOMContentLoaded

window.onLoad 是一个 JS 事件处理函数,它在整个页面以及所有资源(如照片、样式表、脚本等)完全加载后触发。
DOMContentLoaded 只要 DOM 加载完成就触发,无需等待依赖资源的加载。
DOMContentLoaded 比 window.onLoad 执行时间早。

这篇关于JS 的异步加载方法: async、defer、动态加载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/834499

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Java 方法重载Overload常见误区及注意事项

《Java方法重载Overload常见误区及注意事项》Java方法重载允许同一类中同名方法通过参数类型、数量、顺序差异实现功能扩展,提升代码灵活性,核心条件为参数列表不同,不涉及返回类型、访问修饰符... 目录Java 方法重载(Overload)详解一、方法重载的核心条件二、构成方法重载的具体情况三、不构

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注