我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vite打包分割代码的详细过程记录

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vite打包分割代码的详细过程记录

1.什么是代码分割/code spliiting

前端生态 rollup 和 webpack都有的概念。

如果把所有代码都打包到一起,可能最终的代码非常大。从而影响加载时间。

而且,很多代码是初始加载时,不需要的。因此,我们可以根据代码使用的紧急程度,将代码分割打包后,可以按需加载。

2.Vite 中 rollup code spliiting分割默认方法原理

rollup code-spliiting代码分割 默认是由es6 esm(ECMAScript Module)的import, export js模块化功能实现的,CommonJS标准无法实现。

// 提前安装rollup
npm i -g rollup

案例

目录

├─dist
└─class="lazy" data-src
        foo.js
        main.js
        main1.js

(1)按照动态导入语句分割打包测试。

 foo.js
export default 'hello foo!';

// main.js文件
// 动态导入案例1
export default function () {
    import('./foo.js')
    .then(() => {
        // console.log(导入成功);
    })
    .catch(() => {});
}

执行 rollup class="lazy" data-src/main.js   -f cjs -d dist

打包/main.js 生成两个文件

打包后的代码展示

// dist\foo-xxxxxx.js
'use strict';
var foo = 'hello foo!';
exports["default"] = foo;

// dist\main.js
'use strict';

// 动态导入案例1
function main () {
    Promise.resolve().then(function () { return require('./foo-e385385a.js'); })
    .then(() => {
        // console.log(导入成功);
    })
    .catch(() => {});
}

module.exports = main;

按照动态导入语句分割打包测试验证成功。

(2)按照资源导入入口点分割打包测试。

// foo.js
export default 'hello foo!';
// main.js文件
// 资源静态导入案例1
import foo from './foo.js';
export default function () {
    console.log(foo);
}

// main1.js文件
// 资源静态导入案例2
import foo from './foo.js';
export default function () {
    console.log(foo);
}

执行 rollup class="lazy" data-src/main.js class="lazy" data-src/main1.js  -f cjs -d dist

打包/main.js和/main1.js文件 生成三个文件

打包后的代码展示

// dist\foo-xxxx.js
'use strict';

var foo = 'hello foo!';

exports.foo = foo;

// dist\main.js

'use strict';
var foo = require('./foo-f41bffe6.js');
// 静态导入案例
function main () {
    console.log(foo.foo);
}
module.exports = main;

// dist\main1.js
'use strict';
var foo = require('./foo-f41bffe6.js');
function main1 () {
    console.log(foo.foo);

}
module.exports = main1;

按照资源导入入口点分割打包测试验证成功。

(3)manualChunks函数 手动自定义分割。(下面的案例)

3.如何在Vite中配置(vite.config.ts)代码分割/code spliiting (核心关键)

Vite代码分割方法1

// vite.config.ts
build: {
    // rollup 配置
    rollupOptions: {
        output: {
            // key自定义 value[] 插件同步package.json名称 或 class="lazy" data-src/相对路径下的指定文件 (自己可以看manualChunks ts类型)
            manualChunks: {
                // vue vue-router合并打包
                vue: ['vue', 'vue-router'],
                echarts: ['echarts'],
                lodash: ['lodash'],
                // 两个文件合并成一个helloWorld文件
                helloWorld: ['class="lazy" data-src/components/HelloWorld.vue','class="lazy" data-src/components/HelloWorld1.vue'],
                ...
            }
        }
    }
}

Vite代码分割方法2

// vite.config.ts
build: {
    // rollup 配置
    rollupOptions: {
        output: {
            manualChunks(id: any): string {
                if (id.includes("style.css")) {
                    // 需要单独分割那些资源 就写判断逻辑就行
                    return 'class="lazy" data-src/style.css';
		}
                if (id.includes("HelloWorld.vue")) {
                    // 单独分割hello world.vue文件
                    return 'class="lazy" data-src/components/HelloWorld.vue';
		}
                // // 最小化拆分包
                if (id.includes("node_modules")) {
                    return id
                            .toString()
                            .split("node_modules/")[1]
                            .split("/")[0]
                            .toString();
		}
            }
        }
    }
}

总结

到此这篇关于Vite打包分割代码的文章就介绍到这了,更多相关Vite打包分割代码内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vite打包分割代码的详细过程记录

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

webpack创建项目并打包的详细流程记录

webpack在前端工程领域起到了中流砥柱的作用,理解它的内部实现机制会对你的工程建设提供很大的帮助(不论是定制功能还是优化打包),下面这篇文章主要给大家介绍了关于webpack创建项目并打包的详细流程,需要的朋友可以参考下
2023-03-19

编程热搜

目录