动态导入是使用import()表达式在运行时按需加载模块,返回Promise,支持异步加载。适用于路由分割、条件加载等场景,提升性能。与静态导入的编译时同步加载不同,动态导入可在函数内调用,实现代码分割。需注意构建工具支持和错误处理。现代浏览器兼容性良好,配合Babel可支持旧环境。合理使用可优化加载性能。

JavaScript 动态导入(Dynamic Import)是一种在运行时按需加载模块的方式,它让开发者可以更灵活地控制代码的加载时机,提升性能和用户体验。与传统的静态 import 语句不同,动态导入返回一个 Promise,允许你在需要的时候才加载某个模块。
什么是动态导入?
动态导入使用 import() 表达式,它可以在代码中的任意位置被调用,不像静态 import 必须写在模块顶层。由于返回的是 Promise,你可以结合 async/await 或 .then() 来处理加载后的模块。
例如:
// 静态导入 - 在文件顶部,立即加载
import { someFunction } from './utils.js';
// 动态导入 - 按需加载
button.addEventListener('click', async () => {
const module = await import('./lazyModule.js');
module.doSomething();
});
这种方式特别适合路由切换、条件加载或大功能模块的懒加载场景。
立即学习“Java免费学习笔记(深入)”;
动态导入的应用场景
动态导入的优势在于“按需加载”,适用于以下几种常见情况:
慧博商城系统HuiboShop2011系统特色:1、上百套模板随意下载切换、模板定时更新;2、csv数据导入、数据定向读取,一键导入商品信息,省时、省力; 3、多会员等级管理,一站搞定零售、批发、代销;4、可集成网站分销功能模块,缔造庞大的代理业务链,代理客户一键铺货;5、代码严谨,防SQL注入;前后台用户分开管理,密码不可逆加密;6、简单易操作、只需几分钟搞定一个商城网站;商城后台帐号admin
- 路由级代码分割:在单页应用中,不同页面的代码可以在用户访问对应路径时才加载,减少首屏体积。
- 条件性功能加载:比如只有用户点击“导出 PDF”按钮时,才加载庞大的 PDF 生成库。
- A/B 测试或功能开关:根据配置动态加载不同的模块版本。
- 国际化语言包懒加载:只在用户切换语言时加载对应的语言资源。
与静态导入的区别
静态导入是在编译时确定依赖关系,所有模块都会被打包工具提前分析并包含进构建产物中(即使未实际使用)。而动态导入是运行时行为,模块会被打包成独立的 chunk,在需要时通过网络请求加载。
主要区别总结:
- 静态导入:编译时加载,同步语法,必须在顶层使用。
- 动态导入:运行时加载,异步操作,可出现在条件语句、函数内部等任意位置。
注意事项与兼容性
使用动态导入时需要注意几点:
- 确保构建工具(如 Webpack、Vite、Rollup)支持代码分割,否则无法发挥懒加载优势。
- 动态导入返回 Promise,记得处理异常(catch 错误),避免加载失败导致程序中断。
- 浏览器兼容性良好,现代浏览器都已支持;若需支持老旧环境,应配合 Babel 和 polyfill 使用。
基本上就这些。动态导入为 JavaScript 模块化提供了更强的灵活性,合理使用能显著优化应用加载性能。不复杂但容易忽略。










