JavaScript 脚本异步加载的几种实现方法

 更新时间:2025年10月20日 10:24:39   作者:晚夜微雨问海棠呀  
本文主要介绍了JavaScript 脚本异步加载的几种实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

JavaScript 脚本异步加载主要通过以下方式实现,它们在加载时机、执行顺序和阻塞行为上有明显区别:

一、实现方式及区别

1.async属性

<script src="script.js" async></script>
  • 特点
    • 异步下载脚本,下载完成后立即执行(可能中断 HTML 解析)。
    • 多个 async 脚本的执行顺序不确定(先下载完先执行)。
  • 适用场景:独立脚本(如统计代码、广告加载),无 DOM 依赖或无需严格顺序。

2.defer属性

<script src="script.js" defer></script>
  • 特点
    • 异步下载脚本,但延迟到 HTML 解析完成后、DOMContentLoaded 事件前按顺序执行。
    • 多个 defer 脚本严格按声明顺序执行。
  • 适用场景:依赖 DOM 或需要按序执行的脚本(如库文件+业务代码)。

3.动态创建script标签

const script = document.createElement('script');
script.src = 'script.js';
document.head.appendChild(script); // 添加到文档后开始加载
  • 特点
    • 默认行为类似 async(下载完成后立即执行,顺序不确定)。
    • 可通过 script.async = false 改为按顺序执行(模拟 defer)。
  • 控制权:可自由控制加载时机(例如用户交互后加载)。

4.ES6 模块(type="module")

<script type="module" src="module.js"></script>
  • 特点
    • 默认具有 defer 特性(延迟到 HTML 解析后执行,且按顺序)。
    • 添加 async 属性后行为类似常规 async(下载完立即执行,顺序不确定)。
  • 注意:支持模块化语法(import/export),兼容现代浏览器。

二、关键区别对比

方式是否阻塞 HTML 解析执行顺序保证触发时机
async❌(异步下载)下载完成立即执行
defer❌(异步下载)HTML 解析后,DOMContentLoaded 前
动态脚本(默认)下载完成立即执行
动态脚本+async=false按添加顺序执行
ES6 模块(默认)同 defer

三、使用建议

  1. 优先使用 defer:
    • 将脚本放在 <head> 中,避免渲染阻塞,同时保证执行顺序(如依赖 jQuery 的插件)。
  2. 独立脚本用 async:
    • 用于无依赖的脚本(如 Google Analytics)。
  3. 动态加载非关键脚本:
    • 用户交互后或延迟加载非首屏必需的脚本(如评论区、懒加载库)。
  4. 现代项目使用 ES6 模块:
    • 兼顾模块化和加载性能(需配合打包工具如 Webpack 优化)。

四、注意事项

  • 避免在异步脚本中使用 document.write(可能导致页面崩溃)。
  • 可通过 onload/onerror 事件监听加载状态:
    script.onload = () => console.log('加载成功');
    script.onerror = () => console.log('加载失败');
    
  • 兼容性:defer/async 兼容 IE10+,动态加载无兼容问题。

总结

异步加载的核心目标是减少页面渲染阻塞,根据脚本是否依赖 DOM 或其他脚本选择合适方案:

  • 顺序重要 → defer
  • 顺序无关 → async
  • 精细控制 → 动态加载
  • 模块化项目 → ES6 模块

到此这篇关于JavaScript 脚本异步加载的几种实现方法的文章就介绍到这了,更多相关JavaScript 脚本异步加载内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JS封装通过className获取元素的函数示例

    JS封装通过className获取元素的函数示例

    这篇文章主要介绍了JS封装通过className获取元素的函数,涉及javascript针对页面元素属性的遍历与数组相关操作技巧,需要的朋友可以参考下
    2016-12-12
  • 简单实现jquery焦点图

    简单实现jquery焦点图

    这篇文章主要为大家详细介绍了如何简单实现jquery焦点图效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • Javascript数组的 forEach 方法详细介绍

    Javascript数组的 forEach 方法详细介绍

    这篇文章主要介绍了Javascript数组的forEach方法详细介绍,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • JS中的THIS和WINDOW.EVENT.SRCELEMENT详解

    JS中的THIS和WINDOW.EVENT.SRCELEMENT详解

    对于js初学着必须理解this和srcElement的应用,这也是面试中经常考到的。下面我们就通过几个示例来详细了解下
    2015-05-05
  • 前端无接口实现Table导出Excel的两种方案

    前端无接口实现Table导出Excel的两种方案

    在日常开发中,表格数据导出Excel是高频需求,多数场景下依赖后端接口返回二进制文件实现下载,但当无后端接口支持时,前端也可通过纯前端方案完成导出,以下是两种实用方案的详细实现与对比,需要的朋友可以参考下
    2025-08-08
  • js实现图片局部放大镜效果的示例代码

    js实现图片局部放大镜效果的示例代码

    这篇文章主要为大家详细介绍了如何利用JavaScript实现图片局部放大镜效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12
  • javascript中的一些注意事项 更新中

    javascript中的一些注意事项 更新中

    记录一下这些内容只是以后查阅起来方便,作为自己知识积累的记录。其中有很多是参考网络上的资源,不再一一写出出处,还请原作者见谅。
    2010-12-12
  • JS实现网页上随滚动条滚动的层效果代码

    JS实现网页上随滚动条滚动的层效果代码

    这篇文章主要介绍了JS实现网页上随滚动条滚动的层效果代码,涉及JavaScript页面元素属性的获取、运算及设置等操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • 原生JS实现多条件筛选

    原生JS实现多条件筛选

    这篇文章主要为大家详细介绍了原生JS实现多条件筛选,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • TypeScript中yield和Generator的使用指南

    TypeScript中yield和Generator的使用指南

    本文主要介绍了TypeScript中Generator与yield的用法,涵盖其语法、类型定义、典型应用场景及注意事项,具有一定的参考价值,感兴趣的可以来了解一下
    2025-08-08

最新评论