原创不易,但愿能关注下咱们,再顺手点个赞~~ |
本文首发于政采云前端团队博客: 前端工程实践之可视化搭建系统(一)前端
随公司业务不断发展,营销活动、广告、页面改版等需求日益倍增,靠纯人工撸代码已经没法跟上需求增加速度。加班?招人?显得不够明智,也不够前端,提效也就成为了关键。如何提效?从何入手?那不得不提的就是前端提效神器 —— 搭建系统,下文将从多个方面,向你们简单介绍政采云前端团队 ZooTeam 的可视化搭建系统 —— 鲁班。vue
鲁班是一个基于业务组件快速生成页面的搭建系统。数据库
这是一个不得不说的故事,那年冬天......言归正传,我刚来公司时,其实公司有一个叫作 “lunatone” 的项目,这个怎么读呢:露娜汤姆,差很少是这样吧。这个项目中也有一个陈旧的搭建系统,该系统基于栅格布局,能够配置一点数据,组件能够拖拽、嵌套,看着仍是挺酷的,可是问题也很多:后端
基于以上缘由,并在咱们“堂主”大人的“怂恿”下毅然决然的开始了鲁班之旅,一去不复返。api
鲁班从前端架构 -> 后端架构 -> 数据库设计 -> 部署方案设计 -> 容灾方案设计,都是由前端开发人员进行设计、编码。数组
下图为鲁班搭建页面的使用步骤图性能优化
从前台管理系统提及,从使用者角度看鲁班如何搭建一个页面。服务器
组件,咱们也称之为物料,它做为鲁班系统的基础须要被合理的管理。组件来源于 Git 库,从 Git 同步信息到数据库,并拉取源码到服务器进行管理。组件管理页面只需三个操做:微信
开放此功能主要为了方便开发人员开发过程当中进行 Schema 校验。左侧输入符合规范的 Schema 数据,右侧会根据左侧输入显示配置项。架构
可视化搭建平台是鲁班的灵魂。从图中能够看到,左侧是能够被用来搭建的全部组件,目前咱们对组件进行了功能分类,后续将对用户开放更多维度的分类,方便用户进行组件查找。
中间部分是搭建区域,用户能够在这个区域内看见页面的实时效果,能够点击组件进行组件数据配置。
右侧是全部已经被页面使用到的组件,能够对组件版本进行升级,也能够删除不想使用的组件,还能够上下拖动调整组件在页面中的顺序。
在这个平台上,用户不只能够搭建页面、配置数据,还能够在真实环境对页面进行实时预览。
针对页面,平台提供自动埋点、配置数据纠错功能。
针对组件,平台提供组件更新、异常组件报警功能。
最后,点击保存将页面数据提交到数据库。至于数据怎么转成静态 HTML 做为“课后做业”,谨记“堂主”名言:方法总比困难多。╭(●`∀´●)╯╰(●’◡’●)╮
组件数据配置支持 String、Number、Boolean、Array、Object、Color、Select、Upload、Two-dimensional Array(二维数组)等配置字段类型。
简单类型示例:
二维数组示例:
经过以上步骤,咱们就能够搭建出一个页面,点击发布到不一样环境上便可。
先说说咱们最多见的路由,就拿 Vue-Router 举例:经过不一样的 URL 访问不一样的页面。
先进入 Nginx 层,经过 Nginx 通配规则跳转到鲁班服务器,在鲁班服务器上再经过站点、区划、URL、页面状态从数据库查找页面,若是页面存在,根据页面标识从本地返回,若是本地不存在,尝试从 OSS 获取;若是页面不存在,则返回 404 页面。
这里,我就把这价值一个亿的代码偷偷的告诉你们(但愿本身不要被劝退/(ㄒoㄒ)/~~,你们是否是要点个赞,评个论,双击 666,铁汁们!!)
没错!这就是鲁班系统的核心代码,基于 Vue 的 “is” 特性实现。为你们附上 Vue 官方文档:cn.vuejs.org/v2/api/#is
搭建页面是鲁班的核心功能,提效是鲁班系统的核心价值,从 6 月中旬上线至今已经 3 月有余,鲁班获得了公司的高度承认,并被应用到各个重点业务线,从数据上来看,前途一片光明呐。(ง •̀_•́)ง
鲁班系统是前端体系化建设过程当中不可或缺的一部分,也是前端提效的必经之路。它不只避免了组件的重复开发,收敛了简单配置后台,而且为运营角色赋能:运营能够直接在平台上进行页面搭建,经过测试后可随时发版。
鲁班系统的流程设计,遵循公司的 PMO 项目管理流程,但又不拘泥于此,作了必要的突破并化繁为简,被业务方和使用方普遍承认。
鲁班系统已和 Web 性能优化分析系统(百策系统)打通,可以在上线时,查看页面性能评分,不及格可不准发布哦,若是你想了解百策系统,请点击咱们的另外一篇原创文章自动化 Web 性能优化分析方案
后续,我将为你们一一讲解鲁班的系统架构、技术要点、数据库设计、部署方案、容灾策略等。欢迎你们先关注微信公众号 “政采云前端团队”,或者掘金上关注 “政采云前端团队”,以便第一时间获取最新信息。
招人,前端,隶属政采云前端大团队(ZooTeam),50 余个小伙伴正等你加入一块儿浪~ 若是你想改变一直被事折腾,但愿开始能折腾事;若是你想改变一直被告诫须要多些想法,却无从破局;若是你想改变你有能力去作成那个结果,却不须要你;若是你想改变你想作成的事须要一个团队去支撑,但没你带人的位置;若是你想改变“5年工做时间3年工做经验”;若是你想改变原本悟性不错,但老是有那一层窗户纸的模糊… 若是你相信相信的力量,相信平凡人能成就非凡事,相信能遇到更好的本身。若是你但愿参与到随着业务腾飞的过程,亲手参与一个有着深刻的业务理解、完善的技术体系、技术创造价值、影响力外溢的前端团队的成长历程,我以为咱们该聊聊。任什么时候间,等着你写点什么,发给 ZooTeam@cai-inc.com