Vue项目组件化工程开发实践方案


Posted in Javascript onJanuary 09, 2018

我们暂时给提取出来的脚手架取名叫vde-cli,通过vde-cli脚手架生成的组件库工程目录结构如下:

Vue项目组件化工程开发实践方案 

核心功能

组件库

工程的packages文件夹就是用来存放组件库里面的各种组件了,这里不需要通过手动创建文件的方式创建组件,直接通过一条创建组件的命令完成。每个组件都有一个单独的组件文件夹,组件文件夹下都至少包含"index.vue","example.vue","readme.md"这三个文件,这几个文件都是通过创建组件传递的参数加指定的模板生成,创建组件的命令如下:

npm run generate <componentName> <componentTitle>

两个参数分别是组件的名称和后面用来在文档和例子工程里显示的导航名称。

组件库的对外主文件是工程的src/index.js,只要是通过上面的命令创建的组件,这个文件都会自动更新(省去你手工更新的时间)

Doc文档工程

Doc文档工程就是用来展示你组件文档的一个小型单页面系统。组件的文档就是存放在每个组件文件夹下的readme.md文件,我们通过vue-markdown-loader去解析这个文件变成一个vue组件也页面中显示。在你通过上面指令创建组件的时候,会自动更新Doc文档工程的所有依赖组件的部分(不需要任何手工操作)

Example例子工程

Example例子工程跟Doc文档工程类似,用来展示你组件的例子的小型单页面系统,组件的例子就是存放在每个组件文件夹下面的example.vue文件。在通过指令创建组件的完毕,就可以在该文件里测试你写的组件了。

上面的文档工程和例子工程分别通过webpack-dev-sever起了一个对应的服务,添加组件和修改组件文件下的文件信息都会自动刷新这两个应用。

用一张图来表示整个大工程的流程图如下:

Vue项目组件化工程开发实践方案 

主要实现方式

上面已经介绍了整个大工程其实是由组件库、文档工程和例子工程组成的,当然最核心的东西还是组件了,所以一切还需要从创建组件开始说起:

所有的组件都存放在大工程的packages里面,也就是说packages是所有组件存放的根目录(跟组件配置信息相关)。 首先需要说明的是,每个组件文件夹都至少包含组件主文件(index.vue)、组件例子文件(example.vue)、组件文档文件(readme.md)这三个文件。每个组件所包含的这三个文件又是分别通过一个对应的模板文件生成,这三个模板格式可以根据自己的需求自定义,大致类似于:

Vue项目组件化工程开发实践方案Vue项目组件化工程开发实践方案Vue项目组件化工程开发实践方案

通过创建组件的命令传递两个参数,一个代表组件的名称(创建组件的文件夹名称),另外一个是组件的标题(用于文档工程和例子工程的导航名称显示)。有了这两个参数,我们就可以结合组件的模板文件生成对应的组件,然后将这些组件信息写入gen/route.json里面,因为文档工程和例子工程都非常依赖这些信息。 组件创建完毕有一个很重要的工作就是自动往文档工程里面注册新的组件信息(docs/main.js)和更新组件库的对外主文件(src/index.js),这两个文件也分别是通过模板生成的,模板格式分别如下:

Vue项目组件化工程开发实践方案 Vue项目组件化工程开发实践方案

使用

只需要四条命令就能开启一个自动化组件工程了:

1、全局安装vde-cli模块

npm install -g vde-cli

2、初始化工程

$ vde init <project-name>

3、安装所需要模块

$ npm install

4、启动项目

$ npm run start

然后整个工程就能运行起来了,应用的时候可以根据实际需求修改组件相关的模板和加入自己的组件库的其它配置信息就可以了。文档工程和例子工程的路由等信息都会在通过创建组件命令的时候自动更新,你在更改组件的文档和组件功能的时候,文档工程和例子工程都会实时更新。

实际项目接入

这里推荐使用npm link的方式,在项目里npm link本地用vde init的那个工程即可。

总结

以上所述是小编给大家介绍的Vue项目组件化工程开发实践方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JS 控件事件小结
Oct 31 Javascript
用js+iframe形成页面的一种遮罩效果的具体实现
Dec 31 Javascript
PHP开发者必须掌握的6个关键字
Apr 14 Javascript
JS 排序输出实现table行号自增前端动态生成的tr
Aug 13 Javascript
js文件包含的几种方式介绍
Sep 28 Javascript
javascript实现拖放效果
Dec 16 Javascript
this,this,再次讨论javascript中的this,超全面(经典)
Jan 05 Javascript
Vue.js 2.0 移动端拍照压缩图片预览及上传实例
Apr 27 Javascript
jQuery实现所有验证通过方可提交的表单验证
Nov 21 jQuery
微信小程序wx.getImageInfo()如何获取图片信息
Jan 26 Javascript
layui 点击重置按钮, select 并没有被重置的解决方法
Sep 03 Javascript
使用 Opentype.js 生成字体子集的实例代码详解
May 25 Javascript
详解webpack之scss和postcss-loader的配置
Jan 09 #Javascript
SpringBoot+Vue前后端分离,使用SpringSecurity完美处理权限问题的解决方法
Jan 09 #Javascript
详解Webpack+Babel+React开发环境的搭建的方法步骤
Jan 09 #Javascript
详解webpack babel的配置
Jan 09 #Javascript
webpack+vue2构建vue项目骨架的方法
Jan 09 #Javascript
webpack vue 项目打包生成的文件,资源文件报404问题的修复方法(总结篇)
Jan 09 #Javascript
vue.js整合vux中的上拉加载下拉刷新实例教程
Jan 09 #Javascript
You might like
《Re:从零开始的异世界生活 冰结之绊》
2020/04/09 日漫
收集的DedeCMS一些使用经验
2007/03/17 PHP
国外PHP程序员的13个好习惯小结
2012/02/20 PHP
php上传文件,创建递归目录的实例代码
2013/10/18 PHP
PHP封装的数据库保存session功能类
2016/07/11 PHP
PHP中phar包的使用教程
2017/06/14 PHP
jQuery 性能优化指南(3)
2009/05/21 Javascript
jquery交替变换颜色的三种方法 实例代码
2013/11/19 Javascript
原生js和jquery中有关透明度设置的相关问题
2014/01/08 Javascript
jQuery多个input求和的实现方法
2015/02/12 Javascript
node.js中格式化数字增加千位符的几种方法
2015/07/03 Javascript
使用Sticky组件实现带sticky效果的tab导航和滚动导航的方法
2016/03/22 Javascript
NODE.JS跨域问题的完美解决方案
2016/10/20 Javascript
jQuery根据ID、CLASS、等获取对象的实例
2016/12/04 Javascript
node作为中间服务层如何发送请求(发送请求的实现方法详解)
2018/01/02 Javascript
详解nodejs 配置文件处理方案
2019/01/02 NodeJs
[01:35]辉夜杯战队访谈宣传片—LGD
2015/12/25 DOTA
pyqt4教程之实现半透明的天气预报界面示例
2014/03/02 Python
Python通过websocket与js客户端通信示例分析
2014/06/25 Python
python 2.6.6升级到python 2.7.x版本的方法
2016/10/09 Python
mysql 之通过配置文件链接数据库
2017/08/12 Python
python数据处理 根据颜色对图片进行分类的方法
2018/12/08 Python
Pygame的程序开始示例代码
2020/05/07 Python
python实现图片,视频人脸识别(dlib版)
2020/11/18 Python
Python字节单位转换(将字节转换为K M G T)
2021/03/02 Python
利用CSS3动画实现圆圈由小变大向外扩散的效果实例
2018/09/10 HTML / CSS
Html5 webview元素定位工具的实现
2020/08/07 HTML / CSS
SmartBuyGlasses比利时:购买品牌太阳镜和眼镜
2019/08/09 全球购物
供货协议书范本
2014/04/22 职场文书
2014国庆节标语口号
2014/09/19 职场文书
业务员辞职信范文
2015/03/02 职场文书
python实现web邮箱扫描的示例(附源码)
2021/03/30 Python
解决Pytorch dataloader时报错每个tensor维度不一样的问题
2021/05/28 Python
关于CentOS 8 搭建MongoDB4.4分片集群的问题
2021/10/24 MongoDB
实例详解Python的进程,线程和协程
2022/03/13 Python
Python+Selenium自动化环境搭建与操作基础详解
2022/03/13 Python