介绍美团组件化开发的实践过程
2020-12-30 13:59:08 阅读(266) 评论(0)
一位计算机前辈曾说过:Controllingcomplexityistheessenceofcomputerprogramming.随着前端开发复杂度的不断提高,组件开发应运而生,FIS、React等优秀框架的出现遍地开花。这一过程也发生在美团。面对业务规模的快速发展和工程师团队的不断扩张,美团通过引入组件解决资源整合问题,逐步提高组件功能,提高开发效率,重建新一代组件解决方案,适应全栈开发、共享建设,努力“controllingcomplexity”。本文将介绍美团组件开发的实践过程。组件化1.0:在美团早期,前端资源是以页面或类似业务页面的形式组织的。比如order.js对应订单相关页面的交互,account.与账户相关页面相对应的css样式。在过去的很长一段时间里,这种方法继续支持整个项目的正常进展,并取得了突出的成就。随着业务规模的增加和开发团队的扩大,这种机制逐渐显示出一些不足:1。资源冗余页面的逐渐增加,交互的逐渐复杂,导致相应的css和js显著增长,然后出现需要加载整个模块来依赖js中的函数,或者使用css中的部分风格来依赖整个css,冗余资源较多。2.对应关系不直观,没有明显的对应规则。一个问题是,在修改某个业务模块的css或js时,几乎只能依靠grep。依靠人来维护页面模块html、css和js之间的依赖关系容易出错,内容经常被删除,但css或js仍存在问题。依靠人来维护页面模块html、css和js之间的依赖关系容易出错,内容经常被删除,但css或js仍然存在问题。3.单元测试很难以页面为最小粒度集成资源。不同功能的业务模块相互影响,复杂性太高,难以推进自动化测试。自2013年以来,对FIS进行了调查、经过BEM等方案,结合美团开发框架的实际情况,美团初步实现了一套轻量级组件开发方案。主要改进如下:1。以页面功能组件为单位聚合前端资源;2.自动加载符合约定的css、js资源3.将业务数据转换为渲染数据。例如,美团顶部的搜索框实现为一个组件。代码组成:复制代码代码如下:www/component/smart-box/├──smart-box.js #交互├──smart-box.php #渲染数据生产、组件配置├──smart-box.scss #样式├──smart-box.tpl #内容└──test ├──default.js #自动化测试 └──default.php#调用组件变得非常简单:JavaScriptcode将内容复制到剪贴板echo View::useComponent('smart-box', [ 'keyword' => $keyword ]); 对比之前,我们可以看到组件化的一些特点:1。根据需要加载所需的前端资源;2.对应关系非常明确。组件所需的前端资源在同一目录中,责任明确且唯一,对应关系明显;3.易于测试的组件是具有独立显示和交互的最小单元,可以使用Phantom和其他工具进行自动测试。此外,由于前端资源的集中调度,组件化也为高级性能优化提供了空间。例如,实现组件级别的BigRender、资源合并加载是通过数据分析进行的。例如,实现组件级别的BigRender、资源合并加载通过数据分析等。组件化2.0:成熟组件化1.0上线后,由于使用方便,很快得到工程师的认可,并开始应用于各种业务。新的需求接踵而至,一直持续到2014年底,美团在这个阶段称之为组件化2.0。下面介绍几个主要的改进。在高内聚的同时,Lifecycle组件通常需要暴露一些接口供外部调用,以满足复杂的页面需求。例如,在支付密码组件启动后,需要在绑定提交时检查提交订单页面。WebComponents、React等都选择了生命周期事件/方法,美团也是如此。组件的生命周期:一个组件的完整生命周期包括:1.init,初始组件根节点及配置2.fetch,加载css和js资源3.render,内容渲染,默认渲染内容是Bigrender4.ready,数据绑定等操作5.update,数据更新6.destroy,解除所有事件监听,删除所有组件节点组件提供pausee、方便生命周期控制的resume方法。Promise串行用于各个阶段,异步管理更加清晰。各阶段采用Promise串行,异步管理更加清晰。YUI强大的自定义事件系统用于修改默认行为和组件间通信,有效降低了开发维护成本。举个例子,当页面初始化时,组件的启动过程实际上是在生命周期的帮助下实现的:JavaScriptcode将内容复制到剪贴板var afterLoadList = []; Y.all('[data-component]').each(function (node) { var component = new Y.mt.Component(node); // 绑定 init 生命周期事件,在 init 默认行为完成后,执行回调 component.after('init', function (e) { // 若配置了延迟启动 if (e.config.afterLoad) { // 暂停组件的生命周期 e.component.pause(); // 压入延迟启动数组 afterLoadList.push(e.component); } }); // 开始进入生命周期 component.start(); }); Y.on('load', function () { // 在页面 load 当事件发生时,恢复组件的生命周期 afterLoadList.forEach(function (component) { component.resume(); }); }); 回过头来看,除了带来可扩展性外,引入生命周期更重要的是理顺组件的各个阶段,有助于更好地理解和应用。DataBinding数据绑定是美团期待已久的功能。自动化View和ViewModel之间的交互无疑会节省工程师大量时间。DataBinding数据绑定是美团期待已久的功能。View和ViewModel之间的交互自动化无疑将节省工程师大量时间。在组件化中减少注意力和复杂性后,更有可能实现数据绑定。美团最终实现的数据绑定方案主要是指Angular,JS扫描这些内容,并通过在html节点上添加特定的属性声明绑定逻辑进行相应的渲染和事件绑定。当数据发生变化时,所有相应的内容都被重新渲染。JavaScriptcode复制内容<ul class="addressList"> <li mt-bind-repeat="addr in addrList" mt-bind-html="addr.text" > 使用属性声明绑定逻辑的好处是可以同时支持后端渲染,对于美团团购等偏展业务来说,这是非常必要的,用户可以很快看到页面内容。在Flux实现数据绑定后,美团不得不面对另一个问题:如何协调多个组件之间的数据。Flux实现数据绑定后,美团不得不面对另一个问题:如何协调多个组件之间的数据。由于某个组件的数据变化,其他组件很可能会发生变化。举例来说,当购买数量发生变化时,总金额会发生变化,而总金额超过500后,还需要显示大量的消费提醒。为了解决这个问题,美团引入了Flux,利用全球新闻总线的思路进行跨组件交互。例如,在应用组件中,由于交互复杂,美团一直头疼的项目购买页面 Flux重建后,模块之间的互动更加清晰:还有许多其他方面的改进,包括引入模板引擎Lightncandy约束模板逻辑、支持组件任意嵌套、支持异步加载和自动初始化。随着组件化2.0的逐步完善,基本上可以从容应对日常开发,提高效率和质量。组件化3.0:2014年底,美团遇到了一些新的机遇和挑战:基于Node的全栈开发模式开始应用,前后端渲染更有可能停止维护YUI,需要一套新的资源管理方案和新的业务不断增加,需要找到一种组件共享的方式,避免重复造轮结合之前的实践。以及在这个过程中逐渐积累的对行业解决方案的认知,美团提出了一个新的组件解决方案:基于React开发页面组件,使用NPM分发,方便基于Browserify二次开发的共建共享,建设资源包装工具Reduce,方便浏览器加载工程开发解决方案Turbo,以适应组件开发模式,在组件化2.0的过程中,美团发现许多功能与React重叠,如DataBinding等,方便工程师在业务开发中应用组件。、Lifecycle、Flux,前后渲染,甚至直接借鉴。此外,React的函数编程理念、增量更新、兼容性好的事件系统也让美团向往。此外,React的函数编程理念、增量更新、兼容性好的事件系统也让美团向往。借此机会开发前端全栈,美团开始考虑基于React构件3.0。NPM ReduceNPM Reduce构成了美团新的资源管理方案,其中NPM负责组件的发布和安装。可以认为是“分割”的过程。粒度越小,重用的可能性越大。Reduce负责包装页面资源。可以认为是一个“合”的过程,使浏览器能够更快地加载典型的过程
推荐阅读
- 深圳网站设计:如何让网站优化提升效率
网站建设完成之后,应该要做好网站的优化,这样才能够提高网站的效率,也能够达到见证的目的,因为现在的很多企业建立网站都是为了能够更好的营销自己的产品,让更多的人了解到自己的企业,所以说建立网站之后,应该要找到好的提升效率的方案。那…查看详情
- 企业所得税怎么征收?
“企业所得税的征收方式有哪些呢?查账征收是按照利润计算生产经营个人所得税吗?核定征收的核定应纳所得税额如何计算呢?......”在“税法随便问”的平台上,很多小伙伴有这样的疑惑。本篇文章将为您分析作答。一起来看看吧! 企业所得税的征收…查看详情
- 免费录音软件都有哪些?
想要制作一条好的视频,首先必须要有好的录音,尤其是解说游戏这一方面,如果录音不够吸引人,会让别人听着很乏味,因此,我们需要了解免费录音软件都有哪几款,然后运用这几款去录音。 1、简刻录音 有很多的免费录音的基本功能给你们的,…查看详情
- mysql数据库如何连接
在mysql中怎么连接oracle数据库?在开始菜单中,找到oracle11g-应用程序开发-SQLPLUS。双击SQLPLUS。弹出的SQLPlus框中,输入数据库实例的用户名和密码,按enter键。3如果oracle服务器中装有多个数据…查看详情
- 注册公司的地址必须要商业地址么
在注册公司的过程中,公司地址的选择是非常重要的一步。首先,公司地址是公司在法律上的注册地址,也就是说在各级政府部门和企业之间的沟通中,这个地址是至关重要的。为了保证公司的正常运营,公司注册地址必须是真实可靠的商业地址。那么,注册公司的地…查看详情
- b2b网络推广的技巧 五步轻松解决网络推广
在经济快速发展的当下,各种企业层出不穷,市场竞争力越来越大,怎样经营好自己的企业成为各个公司的难题。当然,也不是没有办法,很多小企业分分采取b2b推广的方法,在b2b网站上发布公司的产品和信息,由此宣传了自己的公司和自己的信息。很多人不知道…查看详情
- 专利权许可的方式有哪些?
在平时很多的小伙伴都不知道专利权许可的方式的基本情况,而且对专利权许可的方式都不是很熟悉,下面万商云集*就为大家整理了专利权许可的方式这方面的相关内容,希望下面的内容能帮助到各位。 一、专利权许可的方式有哪些? 第1种,独占…查看详情
- 专利权有哪些属性?专利权的属性介绍
在平时很多的小伙伴都不知道专利权有什么属性的基本情况,而且对专利权有什么属性都不是很熟悉,下面万商云集*就为大家整理了专利权有什么属性这方面的相关内容,希望下面的内容能帮助到各位。 一、专利权的属性介绍 专利权具有以下属性:…查看详情
- 永久免费的看书软件有哪些?免费看书软件推荐
闲来无事的时候,很多人都特别喜欢看小说,而且现在也是移动端使用较多的时代,选择用手机来看小说还是非常不错的,但是在使用手机看小说的时候,也需要找到一款比较好的软件,有些软件需要收费,看到一半之后就不能继续往下看,需要交费用才能看…查看详情
- 2021最新的5款协同项目管理系统软件大盘点
在社会的发展下,个人的合作化变得越来越重要,而协同软件则是一个纽带将所有人联系在一起,我们应该怎样选择这类型的软件,下面我们就来进行协同项目管理系统软件大盘点。 1.帮管客CRM客户管理系统基于先进的CRM营销理念设计,集客户档案、销售记录…查看详情
- 新手如何安装php
如何运行PHP程序?要运行PHP程序,需要在计算机上安装PHP解释器,并且有一个可以运行PHP脚本的Web服务器或者命令行环境。下面是使用命令行环境运行PHP程序的步骤: 编写PHP代码并保存为.php文件。 打开命令行终端,并进入PH…查看详情
- 5G技术将如何赋能小程序?
5G技术革命到来,中小企业再现新的发展机会。2019开启5G元年,大众普遍焦点聚集在各行各业将走向怎样的变革。5G无疑将加快移动应用向移动端、轻量化演进,在移动互联网领域被无限看好的小程序,将会发生什么变化呢?更高效的连接连接是小程序最大的…查看详情
- 分享 | 成都高端网站建设公司有哪些?
随着互联网的发展,网站的兴起,企业开始有了网站建设的需求,便出现了越来越多的网站建设公司。那在众多的网站建设公司中,企业应如何选择呢?接下来,小万就为大家分享一些成都高端网站建设公司。 图片来源于网络 成都高端网站建设公司有哪些呢?◤ 1…查看详情
- 要解决电商系统出售量控制问题,就需要做好库存预警机制!
电商系统出售量控制是电商企业比较关心的问题,也是电商系统需要解决的核心问题之一。很多企业涉及到的产品类目比较多,要准确区分库存充足的产品和库存不足的产品,以及精准送达库存预警信息,这对电商系统库存预警系统要求非常的高。图片来源于网络电商系统…查看详情
- 直播带货怎么找货源 直播带货货源怎么就解决
直播带货的野蛮生长兴起,让网红主播们赚得盆满钵满,直播带货丰厚的佣金让人羡慕眼热。做直播带货,首先肯定要有优质的源源不断的货源。那么,那些网红主播们都是从哪儿得来的货源呢?下面万商云集*就给大家来详细介绍一下直播带货怎么找货源 直播带货…查看详情
猜你喜欢
最新文章

扫码二维码
立即领取《千元实战营销秘籍》
还可免费试用营销管理系统
*如有疑问,请随时拨打免费咨询热线:400-0033-166
邮箱:zjb@iwanshang.com
服务时间:8:30-18:00
软件企业
认定号:川RQ-2018-0216
高新技术企业
认定号:GR201951001121

关注微信公众号
和10万中小企业共同成长

扫码下载APP
享全方位服务一触即达
Copyright © 2004-2022 万商云集(成都)科技股份有限公司 版权所有
蜀ICP备12001963号-2
川公网安备 51010402000322号

快速找产品

找一找哪款产品适合您?
咨询热线:400-0033-166
-


-
电话沟通
获取方案
下载APP
官方微信
扫码下载APP
全方位服务一触即达

关注万商云集
和10万中小企共成长

TOP

企业首选的AI增效平台

400-0033-166
8:30-18:00















































注册有好礼



