背景
最近做的项目需要开发插件功能,要求可以从服务器上加载,那就需要加载动态组件。但是所有需要加载的组件都是动态获取和实例化的,需要作为插件加载进来。那么这些插件如何打包为单独的js文件呢?由于项目用的vue-cli 脚手架,发现了构建目标,打包为库的功能,完美解决痛点。
vue-cli构建默认是应用模式,但是build时可以通过 --target 选项指定不同的构建目标。它允许你将相同的源代码根据不同的用例生成不同的构建。内置的有构建为一个库和构建为一个Web Components 组件2种方式。
1. 项目中用到的是第一种构建为一个库的方式。
在src/views/plugins/components/Demo 下写了个demo.vue示例插件,执行yarn build --target lib --name demo src/views/plugins/components/Demo/Index.vue
命令(demo
表示打包的库名及打包后的文件名字,src/views/plugins/components/Demo/Index.vue
表示库的入口文件),控制台会告诉我们正在构建为一个库:
data:image/s3,"s3://crabby-images/8bcc5/8bcc5e247265797aec6c962a5ef1dc162f9e36f6" alt=""
构建库成功:
data:image/s3,"s3://crabby-images/01c3e/01c3e02afb6c0059144b9623015d695ef502f56a" alt=""
然后会发现项目下会生成一个dist文件夹,各种文件格式官网都有说明:
data:image/s3,"s3://crabby-images/0b2c3/0b2c32f19e0fbe49c8d275d142cdac3707152239" alt=""
demo.html 里面连示例都写好了,直接运行就可以看到效果:
data:image/s3,"s3://crabby-images/084e8/084e81bb44da266874a6d120ae136f3cdf52e2cc" alt=""
这样打包好后的文件就可以上传到服务器上,前端从服务器拉取代码通过下面代码实例化就好了。
data:image/s3,"s3://crabby-images/55ef6/55ef6d3d88149ec763025a89fbaec9885cb0966d" alt=""
- Web Components 组件
执行命令:
yarn build --target wc --name plugin-demo src/views/plugins/components/Demo/Index.vue
plugin-demo 表示web组件的名称,以-的形式更直观更符合规范(这点和库名有所区别),生成的组件可在普通 HTML 中或者其它任何框架中使用。
data:image/s3,"s3://crabby-images/46a36/46a36650236b98612016577606e6e96f4d930320" alt=""
data:image/s3,"s3://crabby-images/fd2a4/fd2a4a437de5d62d9f90a409721b76b4a561a824" alt=""
和构建库一样,编译成功后会生成一个dist文件夹,同样给出了示例,太贴心啦~
data:image/s3,"s3://crabby-images/d3b58/d3b58719991797369d71ff2b7b55c50ad9c2f02d" alt=""
注:
两种打包方式都是将vue排除在外的,使用之前需引入vue
网友评论