教你搭建按需加载的Vue组件库(小结)
按需加载的原理
按需加载,本质上是把一个组件库的不同组件 拆分成不同文件 ,按照需要引用对应的文件,而该文件暴露一个 install方法 ,供Vue.use使用。 比如我只想引用element库里的一个Button组件
import Button from 'element-ui/lib/Button.js' import Button from 'element-ui/lib/theme-chalk/Button.css' Vue.use(Button);
上面的写法比较繁琐,而且需要知道每个组件的实际路径,使用起来并不方便,所以我们还需要借助一个转换插件。
先来看看 element 是怎么做的,官方的的「快速手上」
element使用一个了babel插件,作用就是代码转换
import { Button } from 'ponents' // 转换为 var button = require('ponents/lib/button') require('ponents/lib/button/style.css')
到这我们可以知道,要搭建一个按需加载的组件库。 主要工作 需要两点
- 组件独立打包 ,单个文件对应单个组件
- 引入 代码转换 的插件
组件代码的编写规范
我们在项目的跟目录建一个文件夹packages,狼蚁网站SEO优化放我们的组件:
packages下每一个文件夹对应一个组件所需要的资源,在index.js定义组件的install方法。而packages/index.js存放了在全量加载时用的install方法
packages/Button/index.js:
import Button from './src/main'; Button.install = function(Vue) { Vue.ponent(Button.name, Button); }; export default Button;
packages/Button/src/main.vue:
<template> <div> 我是一个Button组件 </div> </template>
packages/index.js:
import Button from './Button'; import Loading from './Loading'; import LoadMore from './LoadMore'; const ponents = [ Button, LoadMore, Loading ]; const install = function(Vue) { ponents.forEach(ponent => { Vue.ponent(ponent.name, ponent); }); } if (typeof window !== 'undefined' && window.Vue) { install(window.Vue) } export default { install, // 全量引入 Button, LoadMore, Loading };
webpack配置
组件代码写好了,接下来需要配置一下webpack的打包逻辑。我们复用vue-cli生成的模板,在上面做一些必要更改
多入口
每个组件独立生成一个对应的js和css,这就需要我们在入口处就把组件的引用定义好
webpack.prod.conf.js:
const entrys = { Button: path.resolve(__dirname, '../packages/Button'), index: path.resolve(__dirname, '../packages') }; const webpackConfig = merge(baseWebpackConfig, { entry: entrys, // ...... });
上述配置每增加一个组件都需要修改entrys,我们可以优化一下,使其 动态生成
webpack.prod.conf.js:
const entrys = require(./getComponents.js)([组件目录入口]); const webpackConfig = merge(baseWebpackConfig, { entry: entrys, ...... });
getComponents.js:
const fs = require('fs'); const path = require('path'); / 判断刚路径是否含有index.js @param {String} dir / function hasIndexJs(dir) { let dirs = []; try { dirs = fs.readdirSync(dir); } catch(e) { dirs = null; } return dirs && dirs.includes('index.js'); } / 获取指定入口和入口下包含index.js的文件夹的路径 @param {String} entryDir / const getPath = function(entryDir) { let dirs = fs.readdirSync(entryDir); const result = { index: entryDir }; dirs = dirs.filter(dir => { return hasIndexJs(path.resolve(entryDir, dir)); }).forEach(dir => { result[dir] = path.resolve(entryDir, dir); }); return result; } module.exports = getPath;
修改webpack的输出
默认生成的js文件并不支持ES6引入,在这里我们设置成 umd
output: { path: config.build.assetsRoot, filename: utils.assetsPath('[name].js'), library: 'LoadOnDemand', libraryTarget: 'umd' },
配置 babel-plugin-ponent -D
上面的组件库打包发布到npm上之后。我们在使用的时候npm install babel-plugin-ponent -D之后,修改一下.babelrc.js:
"plugins": [ [ "ponent", { "libraryName": "load-on-demand", // 组件库的名字 "camel2Dash": false, // 是否把驼峰转换成xx-xx的写法 "styleLibrary": { "base": false, // 是否每个组件都默认引用base.css "name": "theme" // css目录的名字 } } ] ],
这里提一下属性 camel2Dash ,默认是开启的,开启状态下假如你的组件名是vueCompoent,引用的css文件会变成vue-ponent.css。
上面demo的代码放在了个人github 大家如果有更好的实现方法,或者我上面还有什么需要更正的错误,欢迎交流。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程