动态导入通过import()实现按需加载,提升首屏速度与资源利用率,结合构建工具可拆分代码,适用于路由和功能模块分割,优化大型应用性能。
在现代前端开发中,动态导入(Dynamic Imports)是实现代码分割(Code Splitting)的重要手段。它允许你在运行时按需加载模块,而不是在初始加载时就引入所有代码。这对于提升页面加载速度、优化资源利用非常有效。
动态导入是 ES2025 引入的特性,通过 import() 函数语法实现。它返回一个 Promise,该 Promise 解析为模块对象。这与静态的 import 语句不同,静态导入在文件加载时就确定依赖关系。
示例:button.addEventListener('click', () => {
import('./module.js')
.then(module => {
module.default();
})
.catch(err => {
console.error('模块加载失败', err);
});
});
上面这段代码只有在用户点击按钮时才会去加载 module.js,实现了真正的“按需加载”。
代码分割的目标是将打包后的 JavaScript 文件拆分成多个小块,让浏览器只加载当前需要的部分。结合动态导入和构建工具(如 Webpack、Vite 或 Rollup),可以自动完成这一过程。
const routes = {
'/home': () => import('./pages/Home.js'),
'/about': () => import('./pages/About.js'),
'/admin': () => import('./pages/Admin.js')
};
function navigate(path) {
routes[path]()
.then(({ default: Page }) => {
render(Page);
});
}
这样每个页面对应的代码会被打包成独立的 chunk,访问哪个页面才加载哪个模块。
相比一次性加载全部脚本,动态导入带来几个关键好处:
于维护:逻辑上分离模块,构建工具自动处理拆分尤其在大型应用中,合理使用动态导入能显著降低初始包体积。
虽然动态导入很强大,但也需要注意以下几点:
基本上就这些。动态导入 + 构建工具配合,是目前最主流的前端代码分割方案。用好它,能让应用更轻快。不复杂但容易忽略细节。