微前端是一种前端开发的架构方法,已经变得越来越流行,这也预示着它很可能代表 Web 开发的未来。所以学习这种架构带来的好处对你的应用程序和开发团队是不言而喻的。
本文将分享我和我的团队使用这种方法两年来的经验所得,以及帮助你分析在你的下一个项目中采用它的重要理由。
在过去的几年里,IT公司已经开始将大型软件分解成更小的、更容易管理的模块。这种方法背后的想法是拥有许多可以独立开发、测试和部署的服务。
这就是微服务架构在后台开发方面的作用。但同样的方法也可以应用于前端开发,它被命名为微前端架构。在 Martin Fowler 的官方网站上,微前端方法被定义为。
一种架构风格,将可独立交付的前端应用程序组合成一个更大的整体
这种前端开发的架构方法已经变得越来越流行,因为传统的单片式方法存在着众所周知的隐患。主要是因为前端软件往往增长迅速,而当使用单体架构时,一切都变得更加难以维护。
另一方面,微前端使你有能力实现一个不太复杂和麻烦的架构。特别是,由于微前端的方法,你可以将整个应用程序分割成小的、独立的部分。然后,它们中的每一个都可以由不同的前端团队来实现,甚至可以使用不同的技术。这确保了与后端微服务架构相同的可扩展性、灵活性和适应性。此外,这种方法允许你在同一个网页上混合使用库或不同框架开发的微型前端组件。
所以,微前端现在是IT界的一个趋势,而且这种方法正被越来越多的人采用。
使用微前端开发要了解这种前端开发方法的真正优势是什么。
现在,让我们来看看使用它的五个最相关的理由,这些理由是我作为一个使用微前端工作了两年多的前端开发者的经验总结。
我工作的团队由具有不同背景和技能的开发人员组成。有些是 React 的专家,有些更擅长 Vue.js 或 Angular ,有些人喜欢用 JavaScript 编码,有些人喜欢用TypeScript。
最初,这种现象成为了团队发展的一个障碍。唯一的解决方案是找到共同点,尽管这种选择会迫使一些开发人员学习新技术,并失去他们的专业知识。因此,我们寻找解决方案,并决定采用微型前端架构方法。
得益于此,我们能够将原来的团队分成多个团队,每个人都能在其中表现自己的最佳状态。这是因为不同的团队可以根据他们要处理的业务逻辑,在架构、测试和编码风格方面做出最佳决定。另外,这种方法本质上导致了代码和风格的隔离,使每个团队独立于其他团队。
在最终结果方面,微前端也是有帮助的。这是我们的团队在完全接受这种方法后的体会和结论。事实上,有多个小团队可以自由使用他们喜欢的技术,这意味着他们本质上受到的限制更少,因此更有动力去写出更高质量的代码。
由于微型前端是由独立的小块组成的,所以每一个都可以使用不同的技术栈来实现。这是一个令人难以置信的巨大优势。首先,因为起始团队可以根据特定技术栈的专长分成许多小团队,这也尊重了单一责任原则。其次,由于许多技术栈会在同一个项目中使用,因此雇用新的开发人员变得更加容易。
此外,微前端的方法实际上消除了对某一特定技术的锁定现象,至少它大大减少了这一现象。这是因为你的团队可以随时决定选择一个新的技术栈,而不必翻译以前开发的东西。另外,微前端架构所包含的每块内容肯定比前端单体要小,把它翻译成新的技术会花费更少的时间。
自从我们的团队接受了微前端的方法,我们就被激励着去尝试新的技术、库和框架。事实上,每当你必须在你的应用程序中嫁接一个新的部分,你可以决定采用一个全新的技术栈。这代表了一个宝贵的机会,可以学习如何使用市场上的许多 JavaScript 框架。
通过采用微前端我们作为一个团队的前端开发过程得到了高度改善。主要原因是,我们现在不再有一个大的团队被迫处理不可避免的沟通开销,而是属于较小的独立团队,同时处理不同的功能,而不考虑实施细节。
你可以想象,这也代表了在发布新功能时的一个巨大进步。主要原因是与大型单片机软件相比,构建小型微前端更快、更容易。因此,你的部署时间也会大大改善。事实上,每当一个团队完成了一个功能的工作,他们就可以在线部署,而不需要等待。
换句话说,微型前端应用程序是基于独立的团队同时进行独立的功能工作。不得不说这是一个实现更高发布率的机会,特别是随着小团队数量的增加。
如果你曾经处理过大型的应用程序,你就知道它们很容易变得难以维护,特别是当它们是单体的,而且必然会越来越大。而微前端是基于分而治之的方法,这意味着,如果你的网络应用程序选择这种架构,你可以使每一个业务需求更容易测试和维护。
这一点我们的团队很快就学会了。测试大型单体应用是很有挑战性的,需要大量的时间,我们都知道这一点。但自从我们采用了微前端的方法,一切都变了。现在每个团队负责测试其开发的功能,这些功能远远小于一个完整的前端应用程序。这就加快了开发的速度。这加快了整个过程,使其更容易。因此,现在没有人害怕测试了。而且,每个独立的团队现在可以自由地采用他们喜欢的测试工具和技术。
此外,处理小块的东西意味着理解正在发生的事情的流程变得更加实惠。这导致了建立在许多小部件上的网络应用程序更加可靠,并且在需要时容易被维护。
根据《2020年微服务状况报告》,24%的开发人员已经使用了微前端。这意味着越来越多的公司正在利用这种方法的力量,预计几个流行的前端应用程序将在不久的将来采用这种方法。换句话说,当涉及到前端开发时,微前端可能代表下一步的首选。
我的团队有机会处理这个问题,我毫不怀疑它代表了前端单体开发方法的自然演变。另一方面,它仍然是一个相对较新且有些不成熟的技术,还有很长的路要走。
与此同时,Web 应用程序也在不断发展,但我和我的团队并不害怕说微前端是前端开发的自然演变。
在这篇文章中,我们根据我和我的团队两年来在日常工作中积累的经验,总结了采用微前端架构方法的五个最重要的原因。
虽然没有后端开发中使用的微服务架构那么流行,但它背后的想法几乎是一样的。微前端架构现在成为趋势并不奇怪,它可能代表了前端开发的自然演变。这也是为什么了解它是不可缺少的,学习现在采用它的主要原因就是这篇文章的目的。
介绍了微前端,还有一款工具值得推荐。JNPF开发平台,很多人都用过它,它是功能的集大成者,任何信息化系统都可以基于它开发出来。
原理是将开发过程中某些重复出现的场景、流程,具象化成一个个组件、api、数据库接口,避免了重复造轮子。因而极大的提高了程序员的生产效率。
官网:www.jnpfsoft.com/?csdn ,如果你有闲暇时间,可以做个知识拓展。
这是一个基于Java Boot/.Net Core构建的简单、跨平台快速开发框架。前后端封装了上千个常用类,方便扩展;集成了代码生成器,支持前后端业务代码生成,满足快速开发;框架集成了表单、报表、图表、大屏等各种常用的Demo方便直接使用;后端框架支持Vue2、Vue3。
为了支撑更高技术要求的应用开发,从数据库建模、Web API构建到页面设计,与传统软件开发几乎没有差异,只是通过低代码可视化模式,减少了构建“增删改查”功能的重复劳动。