低代码开发可以说是最近技术圈的顶流,16 年之前还没有 低代码 这个术语,19 年之前几乎没人关注低代码,但从 19 年到现在(2021 年 5 月)的 2 年时间,低代码的搜索指数增长了 10 倍,可见这个领域的受关注程度正在与日俱增。Medium 上的这篇文章(A Brief History Of Low-Code Development)介绍了低代码开发的历史,副标题是回到可视化编程的源头,回顾历史可以让我们更好的把握未来发展的趋势,看清那些在技术演进过程中不变的东西。
以下为正文:
“低代码”是一种可视化编程方法,允许企业不必通过编写代码而是通过图形界面快速搭建应用程序。
虽然“低代码开发”这个术语是在 2016 年由一家市场研究机构为了描述这一类服务提供商而创造的,但低代码背后的想法并不新鲜。在这篇文章中,我们将看到这种模式是如何随着时间的推移而发展的,以及它所面临的问题。
目录
低代码开发平台可以追溯到第四代编程语言——这个概念是在 20 世纪 70 年代到 90 年代发展起来的,与第三代编程语言(3GL)的大部分开发重叠。
James Martin 在他 1982 年出版的《Applications Development Without Programmers》中,认为 4GL 技术(如 RAMIS 和 FOCUS)向更广泛的人群开放了开发环境,并使非程序员能够自己创建应用程序。
第四代编程语言指的是非过程的高级规范语言,包括支持数据库管理、报告生成、数学优化、图形用户界面(GUI)开发和 web 开发。
作为对瀑布模型的响应,当使用 Visual Basic、Delphi 和 Oracle Forms 等可视化编程工具“组装”桌面应用程序的概念开始流行时,我们看到快速应用程序开发(RAD)在 20 世纪 90 年代获得良好的发展势头。
瀑布模型是软件开发行业长期使用的计划驱动过程,它是在 20 世纪七八十年代发展起来的,基于传统的工程模式:
瀑布模型
RAD 工具作为易于学习的开发环境而表现突出,其核心理念是:最终用户应该首先关注 GUI,并逐步添加业务逻辑。
UI 和逻辑都可以存储为组件面板中的组件。
James Martin 定义的 RAD 开发阶段
然而,RAD 工具有其局限性:
为了减少部门和开发之间的距离,对象管理组织(OMG,Object Management Group)在 2001 年推出了模型驱动架构(MDA)。作为一种软件设计方法,它提供了一组指导方针,用于将规范构建和表示为模型。
模型支持域的整体视图,综合考虑技术和业务需求,随后转换为可执行代码。在开发和运行时使用生成器和解释器来生成或解释模型中的代码。
随着 MDA 和微软软件工厂的出现,模型驱动软件开发(MDSD,Model-Driven Software Development)吸引了很多使用 UML(统一建模语言,Unified Modeling Language)和 BPMN(业务流程建模符号,Business Process Modeling Notation)等工具的程序员的兴趣。
随着苹果在 2007 年发布 iPhone iOS 进入移动设备市场,以及一年后谷歌的 Android 问世,各种移动平台应运而生。
开发者积极使用 Android Studio 和 Xcode 等可视化编辑器在本地开发 Android 和 iOS 应用。
这是桌面应用程序在移动设备上的复兴。
然而,响应式网页设计以及增强型 Web 应用(PWA,Progressive Web APPs)等技术已经威胁到了移动应用,因为它们能够为小型设备提供具有良好用户体验(UX)的网页应用,并且不需要依赖特定的移动开发平台。
2016 年,弗雷斯特集团(Forrester Group)发表了一篇文章,此后“低代码”(low-code)一词成为显学。
我们已经看到了低代码开发平台(LCDP,Low-Code Development Platform)的出现——它的起源可以追溯到 2011 年——其目标是将尽可能多的概念整合到一个平台上,从而使编写代码变得不必要或至少显著减少。
低代码平台包含 RAD 和 MDSD 过程,并将 ALM(应用程序生命周期管理,Application Life Cycle Management)以及持续集成(CI,Continuous Integration)或持续部署(CD,Continuous Deployment)集成到开发、测试和生产环境中。
为了支持整个环境的“拖放”创建,必须有 PaaS(平台即服务,Platform as a Service)的支持。通常使用公有云服务提供的 PaaS,但也可以使用企业内部服务(如基于 OpenShift 的容器平台)。
低代码平台的组件和架构
aPaaS(应用平台即服务,Application Platform as a Service)提供了应用程序整个生命周期所需的一切:从一开始的规划阶段一直到开发、验收和运维。
2020 年,新冠疫情的大爆发暴露了许多企业在数字化方面已经落后了。
为了保持他们的业务运作并满足他们的员工和客户的需求,他们被迫升级他们的应用程序,并构建新的应用程序来填补现有的流程空白。
因此,低代码的普及程度得到了提升。这一势头将持续到 2021 年。
像几十年前流行的 4GL 这样的技术,曾承诺能迅速满足客户的需求,但由于一些限制因素,最终失败了,而且它们的流行程度自推出以来就不断的在减弱。
进入 21 世纪,许多 RAD 开发环境已经销声匿迹了。随着为 web 编写应用程序成为趋势,Swing 和 SWT 等“经典”UI 工具包变得越来越没有意义。
UI 设计越来越多地使用 HTML、CSS 和 JavaScript 来完成,这为网页设计师创造了越来越多的工作机会。不同的网页浏览器、操作系统(如 Linux、macOS)以及从 PC 到智能手机再到可穿戴设备的都被当作目标系统。
我们注意当前的低代码服务提供商大多数都学习过历史。他们知道困扰 4GL 和 RAD 的问题,并试图在他们的系统中修复这些问题。
随着企业转向人工智能、机器人、机器学习和物联网等新技术,低代码解决方案也在不断发展,以提供这些能力。
封面图片:灰色金属立方体装饰,来自 Pexels 上 Oleg Magni 拍摄的图片
领取专属 10元无门槛券
私享最新 技术干货