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 相关文章推荐
基于JQuery的浮动DIV显示提示信息并自动隐藏
Feb 11 Javascript
JS+CSS实现简易实用的滑动门菜单效果
Sep 18 Javascript
浅析2种JavaScript继承方式
Dec 04 Javascript
Javascript动画效果(3)
Oct 11 Javascript
详解使用JS如何制作简单的ASCII图与单极图
Mar 31 Javascript
Vue-cropper 图片裁剪的基本原理及思路讲解
Apr 17 Javascript
使用Vue-cli 3.0搭建Vue项目的方法
Jun 07 Javascript
基于Koa2写个脚手架模拟接口服务的方法
Nov 27 Javascript
简述vue路由打开一个新的窗口的方法
Nov 29 Javascript
微信小程序实现的3d轮播图效果示例【基于swiper组件】
Dec 11 Javascript
javascript实现商品图片放大镜
Nov 28 Javascript
vue 使用外部JS与调用原生API操作示例
Dec 02 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
javascript 选择文件夹对话框(web)
2009/07/07 Javascript
JavaScript中变量提升 Hoisting
2012/07/03 Javascript
jquery 面包屑导航 具体实现
2013/06/05 Javascript
javascript显式类型转换实例分析
2015/04/25 Javascript
JavaScript基于ajax编辑信息用法实例
2015/07/15 Javascript
angularJs使用$watch和$filter过滤器制作搜索筛选实例
2017/06/01 Javascript
快速搭建vue2.0+boostrap项目的方法
2018/04/09 Javascript
原生JS进行前后端同构
2018/04/22 Javascript
深入理解Vue nextTick 机制
2018/04/28 Javascript
json字符串传到前台input的方法
2018/08/06 Javascript
vue单页应用在页面刷新时保留状态数据的方法
2018/09/21 Javascript
关于vue.js中实现方法内某些代码延时执行
2019/11/14 Javascript
JavaScript利用键盘码控制div移动
2020/03/19 Javascript
vue实现图片上传功能
2020/05/28 Javascript
[01:00:06]加油DOTA_EP01_网络版
2014/08/09 DOTA
python网络编程学习笔记(四):域名系统
2014/06/09 Python
Python获取系统默认字符编码的方法
2015/06/04 Python
python中闭包Closure函数作为返回值的方法示例
2017/12/17 Python
python-str,list,set间的转换实例
2018/06/27 Python
基于python代码实现简易滤除数字的方法
2018/07/17 Python
微信小程序python用户认证的实现
2019/07/29 Python
python爬虫增加访问量的方法
2019/08/22 Python
加拿大最大的书店:Indigo
2017/01/01 全球购物
日本必酷网络直营店:Biccamera
2019/03/23 全球购物
Tomcat中怎么使用log4j输出所有的log
2016/07/07 面试题
人力资源经理自我评价
2014/01/04 职场文书
《手指教学》反思
2014/02/14 职场文书
辞职信怎么写
2015/02/27 职场文书
2015年双拥工作总结
2015/04/08 职场文书
加薪申请报告范本
2015/05/15 职场文书
高中班主任心得体会
2016/01/07 职场文书
党章学习心得体会2016
2016/01/14 职场文书
Nginx反向代理多个服务器的实现方法
2021/03/31 Servers
Javascript设计模式之原型模式详细
2021/10/05 Javascript
排查并解决MySQL生产库内存使用率高的报警
2022/04/11 MySQL
类和原型的设计模式之复制与委托差异
2022/07/07 Javascript