当前位置: 首页 > news >正文

JavaScript 实现模块懒加载的几种方式

JavaScript模块懒加载通过延迟加载非关键资源提升页面性能,以下是主流实现方式:

一、原生动态导入(推荐方案)

通过ES2020的import()函数实现异步加载,返回Promise对象:

javascript

button.addEventListener('click', async () => { const module = await import('./module.js'); // 动态加载模块 module.doSomething(); // 执行模块方法 });

▲ 特性:

  • 浏览器原生支持,无需额外库。
  • 自动代码分割(code splitting)。
  • 与Webpack/Rollup等构建工具无缝集成。

二、传统模块加载方案

1. Webpack特定语法

javascript

require.ensure([], () => { const module = require('./module'); module.doSomething(); }, 'chunk-name'); // 命名代码块

▲ 适用场景:

  • 兼容旧版Webpack项目。
  • 需显式控制代码块命名。
2. 动态Script注入

原生JS实现的通用方案:

javascript

function loadModule(src) { return new Promise((resolve) => { const script = document.createElement('script'); script.src = src; script.onload = resolve; document.head.appendChild(script); }); } // 使用示例 loadModule('module.js').then(() => { // 模块加载完成后执行 });

▲ 优势:

  • 兼容所有浏览器环境。
  • 支持非模块化脚本加载。

三、进阶优化策略

  1. 交互驱动加载
    结合用户行为(点击/滚动)触发模块加载,减少初始负载。
  2. 预加载提示
    使用<link rel="preload">声明重要模块优先级。
  3. 缓存策略
    通过Service Worker缓存已加载模块,提升二次访问速度。

优先采用原生import()方案,旧项目可渐进式迁移至动态导入。对于图片/视频等资源懒加载,推荐使用IntersectionObserver API实现。

http://www.dtcms.com/a/327323.html

相关文章:

  • 如何轻松解除Facebook封锁
  • flinksql bug: Received resultset tuples, but no field str
  • 阿里云国际DDoS高防:添加网站配置指南
  • 腾讯codebuddy.ai 安装实测【从零开始开发在线五子棋游戏:完整开发记录】
  • 机械学习--TF-IDF实战--红楼梦数据处理
  • wordpress数据库导入时的#1044错误
  • Linux中使用计划任务和tar命令实现文件备份
  • 【Unity】Spine重新播放动画时会闪烁上次动画的残影
  • K8S 节点初始化一键脚本(禁用 SELinux + 关闭 swap + 开启 ipvs 亲测实用)
  • SQL 与 NoSQL 的核心区别
  • 部署高可用5节点 k8s 集群(v1.25.0版本)
  • Python中的高阶函数
  • vue+Django农产品推荐与价格预测系统、双推荐+机器学习预测+知识图谱
  • 六、SpringBoot多环境开发
  • 【Unity笔记】视频播放控制器全攻略:支持延迟播放、事件回调与多视频管理的完整实现
  • Linux 系统下 VS Code 降级至 1.85 版本教程:通过历史版本网站解决兼容性问题
  • 二叉树(七)--完全二叉树的节点个数
  • Day13 Vue工程化
  • mysql 简单操作手册
  • 行业分享丨SimSolid 在汽车零部件开发中应用的可行性调研及实践
  • 鸿蒙har包打包与引用,其它主工程entry引用本地har
  • Wireshark专家模式定位网络故障:14种TCP异常深度解剖
  • 西门子S7-200与S7-1200通过PPI以太网模块通讯,赋能汽车制造行业发展
  • 人机交互:连接人类与数字世界的桥梁
  • 【k8s】pvc 配置的两种方式volumeClaimTemplates 和 PersistentVolumeClaim
  • 计算机网络1-8:第一章 概述 习题课
  • UserController类讲解
  • Git 撤回已推送到远程的最近push
  • Linux 服务器,安装mqtt服务
  • AuthController类讲解