docs/feature/feature2.0/dynamic-import.md
Hippy 2.2 版本之前只支持加载单个 js bundle 文件。随着业务越来越复杂,单个 js 文件体积愈发增加的体积会影响首屏启动速度。为了解决这个问题,Hippy 在 2.2 版本增添了动态加载能力,开发人员可以按需来动态引入子 js bundle 文件。
Hippy 最低版本支持 2.2
npm install -D @hippy/hippy-dynamic-import-plugin
在 Webpack 打包脚本 中引入插件
const HippyDynamicImportPlugin = require('@hippy/hippy-dynamic-import-plugin');
module.exports = {
entry: {
index: 'example.js',
},
output: {
filename: 'example.output.js',
strictModuleExceptionHandling: true,
path: path.resolve('./dist/'),
globalObject: '(0, eval)("this")',
},
plugins: [
new HippyDynamicImportPlugin(),
],
};
在终端 SDK 不支持 dynamic import 的版本,可以使用以下两种方法阻止分包。
/* webpackMode: "eager" */ magic comment 停止生成额外的chunk。具体原理可以参看 webpack magic comment// 在import()中增加magic comment例子如下:
AsyncComponent: () => import(/* webpackMode: "eager" */ './dynamicImport/async-component.vue'),
webpack.optimize.LimitChunkCountPlugin 的 maxChunks 参数。具体原理可以参看 webpack LimitChunkCountPlugin。// 通过配置webpack.optimize.LimitChunkCountPlugin的maxChunks为1,dynamic import 会替换成 Promise.resolve
plugins: [
...,
new HippyDynamicImportPlugin(),
// LimitChunkCountPlugin can control dynamic import ability
// Using 1 will prevent any additional chunks from being added
new webpack.optimize.LimitChunkCountPlugin({
maxChunks: 1,
}),
],
网络加载 hippy sdk 最低支持版本 2.5.5
网络加载 @hippy/hippy-dynamic-import-plugin 最低支持版本 2.0.0
提供以下几种模式
与原有动态加载能力一样,直接使用 import() 语法即可
publicPath(可选) // webpack output 配置
output: {
...
publicPath: 'https://xxxx/hippy/hippyVueDemo/',
},
magic comment的 webpackChunkName(必须) 和 customChunkPath(可选),如果没有配置customChunkPath,会默认使用全局 publicPath;
以 Hippy-Vue 为例: // Hippy-Vue 配置,
AsyncComponentFromHttp: () => import(/* customChunkPath: "https://xxx/hippy/hippyVueDemo/", webpackChunkName: "asyncComponentFromHttp" */'./dynamicImport/async-component-http.vue')
.then(res => res)
.catch(err => console.error('import async remote component error', err))
去除 webpack 全局配置的 publicPath(publicPath 会强制在所有 bundle 前加上配置的路径,影响本地 bundle 加载)
加载远程 bundle,在业务代码引用分包的入口配置 magic comment的webpackChunkName(必须) 和 customChunkPath(必须),以 Hippy-Vue 为例:
// Hippy-Vue 配置
AsyncComponentFromHttp: () => import(/* customChunkPath: "https://xxx/hippy/hippyVueDemo/", webpackChunkName: "asyncComponentFromHttp" */'./dynamicImport/async-component-http.vue')
.then(res => res)
.catch(err => console.error('import async remote component error', err))
magic comment的webpackChunkName (可选),以 Hippy-Vue 为例:// Hippy-Vue 配置
AsyncComponentFromLocal: () => import(/* webpackChunkName: "asyncComponentFromLocal" */'./dynamicImport/async-component-local.vue')
.then(res => res)
.catch(err => console.error('import async local component error', err)),