Introduction:? What is low-code? Why do we need low code? Will low code put programmers out of work? This article summarizes the basic concepts, core values and current state of the industry in the low-code space, bringing you a comprehensive understanding of low-code.
What is Low-Code
What is "Low-Code"? If this is the first time you've heard of it, you're probably doing the same internal drama I did when I heard the term from my boss: what? "Low-Code"? I know "Code" means code, but what does the word "Low" mean? It can't be that my boss realized that the code I wrote recently is very ugly and "Low", right? How could the boss personally review the code? Does that mean "Low" in "Low-level programming"? The boss finally realized that it's a waste to let me and other programming wizards pile up Java business code all day long, and sent me to write a high-performance C language network library in retreat... Obviously not, the boss can't have this technical feelings. Then what does it mean in the end? As a programmer whose search quotient is higher than his emotional quotient, he would never ask his boss if he can ask Google.
Wikipedia Definition
From this Wiki definition, we can extract a few key messages:
A low-code development platform (LCDP) is itself a type of software that provides developers with the ability to create and manage their own applications. It provides a development environment for developers to create applications. Doesn't the word "development environment" sound familiar? For programmers, the nature of the LCDP is almost the same as IDEA, VS, and other code IDEs (integrated development environments), which are productivity tools for developers. Unlike traditional code IDEs, low-code development platforms provide a higher-dimensional and easy-to-use visual IDE, and in most cases developers do not need to program in the traditional hand-written code way, but can do so in a more efficient way through graphical drag-and-drop, parameter configuration, and so on.Forrester Definition
Following the Wiki's description, it turns out that the term "Low-Code" was coined by Forrester as early as 2014, and its granddaddy definition of a low-code development platform goes like this:
Click on the image to describe it. Enter image description
This definition is more oriented toward articulating the core value of low-code than the Wiki version:
Low-code development platforms enable rapid delivery of business applications. That is, rather than just "being able" to develop applications like traditional development platforms, the focus of low-code development platforms is on developing applications "faster". What's more, the degree of speed is disruptive: according to Forrester's research in 2016, most companies reported that low-code platforms helped them improve development efficiency by 5-10 times. And there's reason to believe that as low-code technologies, products, and the industry continue to mature, this improvement multiple will continue to rise. Low-code development platforms reduce the cost of developing business applications. On the one hand, low-code development in the software lifecycle process on the input are lower (less code writing, environment setup and deployment costs are simpler); on the other hand, low-code development also significantly reduces the threshold of the use of developers, non-professional developers after a simple IT basic training can be quickly on the job, not only to fully mobilize and utilize all aspects of the existing human resources of the enterprise, but also significantly reduce the dependence on expensive professional developer resources. expensive professional developer resources.Low-code core capabilities
Based on the above definitions and analysis, it is not difficult to summarize the core capabilities of these three low-code development platforms:
Please click to enter a description of the picture
Full-stack visual programming: visualization contains two meanings, one is the editing of the support of the point-and-click, drag-and-drop, and configuration, and another is the editing of the completion of the WYSIWYG (What you see is what you get). WYSIWYG (WYSIWYG) preview effect. Traditional code IDEs also support some of the visualization capabilities (such as Visual Studio's MFC/WPF in the early years), but low-code more emphasis on full-stack, end-to-end visual programming, covering the various technical aspects of a complete application development (interface/data/logic). Full lifecycle management: As a one-stop application development platform, low-code supports the complete lifecycle management of the application, that is, starting from the design phase (some platforms also support more front-end project and requirements management), through development, building, testing and deployment, until after the launch of a variety of operations and maintenance (e.g. monitoring and alarms, application upload/download) and operations (e.g. data reporting, user feedback).Low code scalability.
Low-code scalability: When using low-code development, most cases are still inseparable from the code, so the platform must be able to support the application through a small amount of code when necessary to flexibly extend the application at all levels, such as adding custom components, modifying the theme CSS styles, and customizing the logic of the flow of action. Some possible requirement scenarios include: UI style customization, legacy code reuse, specialized encryption algorithms, and non-standard system integration.It's not just about writing less code
Back to the original question that struck close to home: what does the "Low" in Low-Code mean? The answer is obvious: it doesn't mean that the level of abstraction is low (on the contrary, the level of abstraction of low-code development is one level higher than that of traditional programming languages), nor does it mean that the code is low (on the contrary, the code generated by low-code is usually well-maintained and tested, and the overall quality is better than that of most hand-written code), but it is simply "write less code! It's simply "write less code" -- write code by hand only in the few cases where it's needed, and most of the time use visualizations and other non-code solutions.
Looking a little deeper, low-code is more than just writing less code: the less code you write, the fewer bugs you'll have (the less you do, the fewer mistakes you'll make), which is why two of the pillars of development are "catching up on requirements" and "fixing bugs". The two pillars of the development process, "catching up with requirements" and "fixing bugs" are less; less code to test, so test cases can be written less; in addition to the development phase, the platform also covers the subsequent application construction, deployment and management, so operation and maintenance operations are also less (Low-Code → Low-Ops).
However, less is not the ultimate goal: if you simply want to achieve the effect of less, it is just as easy to cut demand and reduce labor, and lower quality requirements. The philosophy behind low-code is Less is More, or more accurately, Do More with Less -- more capacity, faster on-line, better quality, and less cost, which profoundly fulfills the essence of Ali's values. It is a deep realization of Ali's value of "both, and also, and also".
Please click to enter image description
Platform responsibilities and challenges
The above is the ability and attractiveness of low-code to developers, so as a service provider and application bearer, low-code development platforms themselves should assume what responsibilities, which will encounter how much challenge? Is it necessary to "leave the complexity to yourself and the simplicity to others" as advocated by Aliyun? Although this sentence sounds very clear, but I wonder if we have ever thought, why must we hold complexity not to let go, for no reason to find their own problems? Can't we just kill the complexity and leave some simplicity for our own employees? The KPI value is not reflected in the work is too easy, or the meal at home is not as good as the company's midnight snacks?
After pondering for a long time, I found the answer from the first law of thermodynamics: the total complexity of developing an application is constant, and can only be shifted without disappearing. In order for developers to do less and enjoy the joy of simplicity, then the platform side has to do more and silently take on as much complexity as possible. It's like an acrobat with a full body of tendons steadily lifting a female partner who is spinning and jumping high above; the lighter and more effortless the person above appears, the more stable and more exhausted the person below has to be. Of course, it's not that the actresses on top are relaxed and stress-free, it's just that they each have a different division of labor and a different level of complexity.
According to Fred Brooks, author of The Myth of the Man-Month, the complexity of software development can be categorized as Essential complexity and Accidental complexity. The former is the minimum complexity inherent in solving a problem, and has nothing to do with what kind of tools you use, whether you are experienced or not, whether the architecture is good or not, etc., while the latter is in addition to the complexity introduced in the actual development process. Typically, intrinsic complexity is strongly related to the specific problem domain that the business is trying to solve, so I'll refer to it here as the better-understood "business complexity"; this part of the complexity can't be solved by any development methodology or tool, including low-code. Incidental complexity, on the other hand, is generally strongly related to the technical details of the development phase, so I'll call it "technical complexity" accordingly; this is the part of complexity that low-code is good at, and suited to, solving.
Shielding developers from the underlying technical details, minimizing unnecessary technical complexity, and enabling them to better cope with business complexity (to meet the needs of flexible and generic business scenarios) is the core responsibility of a low-code development platform.
Please click to enter image description
In addition to the above responsibilities, the low-code development platform, as a developer-oriented product, also needs to be committed to providing developers with a simple and intuitive development experience. In addition to the huge amount of work involved, it is also necessary to find a balance between "powerful" and "easy to use", which is difficult to achieve, and to meet the needs of the product and its target customers - this is perhaps the most important aspect of designing a universal low-code development platform. - This is perhaps the biggest challenge in designing a general-purpose, low-code development platform.
Three low-code related concepts
Pro-Code / Custom-Code
The term "Pro-Code" may be something I made up, but it's more commonly referred to as Pro-Code or Custom-Code. Custom-Code); but they all mean the same thing, that is, the traditional Code-Centric development model. The reason I chose to use "Pro-Code" is that if I use "Pro-Code", it would seem as if low-code is not professional, while "Custom-Code" is easily misunderstood as low-code can't support customized custom code. code can't support customized custom code.
Of course, a more accurate term would be "high-code" (which corresponds to low-code, but is just too ugly a name for me to use...) The reason is that even with traditional coding IDEs, there are some development tasks that are supported (or even better suited) to be done in a non-coding way, such as the SwiftUI interface designer for iOS development, or the PowerDesigner modeling tool for server-side development of database applications. However, this part of the visualization work in the traditional development model only plays a supporting role, and usually ends up generating code that the developer can directly modify; the developer is still centered on the code to carry out the main work.
The relationship between low-code and pure code is a lot like the relationship between videos and articles:
Low-code is like a modern-day "video," in that most of the content consists of easy-to-understand, expressive images, and is therefore more accessible to the general public. But at the same time, video is not so rigid that it can only have pictures, and it is possible to add a small amount of text (e.g., subtitles, annotations) to make up for the lack of precision in the pictures. btw, for more information on the dialectic between "diagrams" and "text", please refer to Architecture Mapping: Tools and Methodologies [1].
Pure code is more like the traditional "article", which has been the only medium for information dissemination for a long time, but has gradually begun to lose ground since the advent of video technology and the spread of the corresponding hardware and software infrastructures. Nowadays, video has become the main channel for most people to get information (from TV and movies to B-station Shake), while fewer and fewer people regularly read books and articles. However, it is undeniable that the article still has its meaning and audience (otherwise I would not have bothered to type so many words), even if the "market share" has been squeezed, but there will always be a space for it to stand.
Please click to enter a description
If you follow the analogy above, low-code will follow a similar trajectory to video, overtaking pure code as the dominant development model, and Gartner's predictions say the same thing: by 2024, 65 percent of all application development will be low-code, and 75 percent of large enterprises will use at least one code code. By 2024, 65 percent of all application development will be done in low-code, and 75 percent of large organizations will use at least four low-code development tools for application development.
But in the same way that video will never replace an article, low-code will never replace pure-code development. In the future, low-code and pure-code approaches will exist in a complementary form for a long time***, and each will shine in the business scenarios for which they are suitable. In the "low-code business scenarios" section later, we will list in detail which scenarios are more suitable for low-code mode development at this stage.
Zero-Code (No-Code)
From the point of view of completeness of categorization, it is natural that there should be "pure code" and the exact opposite, "zero-code" (also called "no code"). Zero-code is an application development platform that requires no code at all, but this does not mean that zero-code is more advanced and advanced than low-code, it just makes a more extreme choice: completely embrace simple graphical visualization and completely eliminate complex text code. The reason behind the choice is that the zero-code development platform expects to minimize the threshold of application development, so that everyone can become a developer (note: develop ≠ write code), including business analysts, user operations, and even product managers who know absolutely nothing about code (not pretending to know is not considered to know).
Even for professional developers, in the trend of increasingly fine-grained technical division of labor (front-end/back-end/algorithms/SRE/data analysis...) , it's also hard to recruit a full-stack engineer who can independently develop and maintain a whole set of complex applications. But zero code can change all this: whether it is Java and JavaScript stupidly unclear technology white, or proficient in deep learning but do not have time to learn Web development algorithmic bull, can be zero code to realize their own technical dreams or full-stack dream. The joke that "there's already a world-changing IDEA out there, all that's missing is a programmer" might actually come true; oh no, it doesn't even need a programmer, the person with the IDEA can get on by himself.
Please click to enter a description
Of course, all choices come at a price, and zero code is no exception. The price of completely abandoning code is limited platform capability and flexibility:
On the one hand, the expressive power of a visual editor is far less than that of a Turing-complete general-purpose programming language, so it's impossible to achieve flexible customization and extension without introducing code (of course, theoretically, it could be made into a graphical programming language like Scrach/Blockly, but that would be just another form of handwritten code! .) On the other hand, since the target audience is non-professional developers, the platform supports more "dumbed-down" operations (e.g. pages that support simple stacking of large business components, not fine-grained atomic components and flexible CSS layout definitions), and only provides a relatively "user-friendly" interface. "folksy" models and concepts (e.g. using "tables" to represent data instead of "databases"), and not supporting strong and professional underlying development languages and programming concepts.Please.
Please click to enter a description
While there is a clear difference between zero code and low code in the narrower sense of the term, in the broader sense zero code can be considered a subset of low code, and it is this broader sense of low code that Gartner categorizes as "No Code" in its research report. Gartner in its research report, is "No Code" in the broader scope of low-code application platform "LCAP" (Low-Code Application Platform). Many of the general-purpose low-code development platforms on the market today also have some degree of zero-code capability; for example, Mendix, a leader in low-code, offers both an easy-to-use zero-code Web IDE, Mendix Studio, as well as a more powerful low-code desktop IDE, Mendix Studio Pro.
HpaPaaS (High Productivity) is the first low-code application platform on the market. HpaPaaS (High Productivity Application PaaS)
As mentioned above, the term "Low-Code" is attributed to Forrester. Gartner, also an internationally renowned research organization (a.k.a. a word maker), obviously won't easily concede defeat in this new conceptual word contest that may determine the status of the low-code field, so it also invented the term "HpaPaaS" (High-productivity application Platform as a Service) in 2017. productivity application Platform as a Service) in 2017.
According to Gartner's definition, HpaPaaS is a platform that supports declarative, model-driven design and one-click deployment, providing rapid application development (RAD), deployment, and runtime features on the cloud; which is clearly the same as the definition of low-code. But as it turns out, it's not always good to be too specialized, and "HpaPaas" ultimately lost out to the older, more grounded and catchy "Low-Code": starting in 2019, Gartner will also be adopting the term "Low-Code" across the board in its research report on the subject. Starting in 2019, Gartner is also adopting the term "Low-Code" across the board in its research reports (e.g., LCAP), personally putting the @deprecated stamp on "HpaPaaS".
Please click to enter a description
What's the difference between SaaS / IaaS / PaaS / aPaaS / HpaPaaS?
It's worth adding that the term "HpaPaaS" isn't just a term of art. It's worth adding that the term "HpaPaaS" is not an out-of-the-box term, but rather a carryover from Gartner's earlier "aPaaS", which is a subcategory of aPaaS, and that aPaaS is a subcategory of aPaaS, except for HpaPaaS, which is a low-code platform for high-productivity application development, and aPaaS, which is a low-code application development platform. development platform, aPaaS also includes traditional application development platforms oriented to pure code (High-control aPaaS, i.e., a pure code development approach with a higher degree of control).
It's not worth gossiping about, but the term "aPaaS" isn't something that was invented out of thin air, and it goes back a long way with the rise of cloud computing. I'm sure all of you in the cloud world have guessed that aPaaS is in the same vein as IaaS/PaaS/SaaS, the ancient concepts of cloud computing: aPaaS is in between PaaS and SaaS, providing services that are more application oriented than PaaS, but unlike SaaS, it doesn't provide off-the-shelf software services (for a more detailed description, refer to the source article for the accompanying image).
Four, why you need low-code
What is low-code may not be so important, after all, in this world of information explosion, there is never a shortage of new and short-lived things. Most so-called new technologies are short-lived: they appear, they are seen, most people say "oh", read it, but are not interested, and a small number of people marvel at the whimsy of the idea, nod excitedly, and then go back to using it for what it was meant to be used for. What really determines whether a new technology translates into new productivity is never how good or flashy the technology itself is, but whether it's really needed, i.e., why do you need low-code? If you fill in this question with a different subject (cold fact: this is called "delayed subject initialization"), you can get a fuller picture:
Why does the "market" need low-code?
In this era of moncler outlet store uk "Internet+" and "digital transformation," companies increasingly need apps to improve the flow of information within the organization and to strengthen touchpoints with customers. However, the birth of the IT information age has not been too long, is also facing with the primary stage of socialism in China, similar to the contradiction between supply and demand: backward software development productivity can not keep up with the growing business needs of the people.
Please click to enter image description
Gartner predicts that by 2021 the market growth of application development needs will exceed the enterprise IT delivery capacity by at least 5 times. In the face of such a huge IT gap, without a revolutionary "new productivity" system, it's hard to imagine that the problem can be solved simply by continuing the development of existing traditional technology systems. And low-code technology is with such a mission to come, expect the following aspects of application development through a complete revolution in productivity, to save the IT world almost into the hot water:
Efficiency & quality assurance
While the software industry has been in the rapid development of new languages, frameworks, and tools are endless, but as a practitioner we have to admit: Software development is still in the workshop stage, low efficiency, high labor costs, quality is not controllable. Project delivery delays have become the norm in the industry, and the bottleneck is almost always the developer (to the machine can solve the problem is not a problem); excellent development talent is always a scarce resource, but also thief expensive; software quality defects can not be converged, online failures are frequent capital loss.
In contrast, the traditional manufacturing industry after hundreds of years of development of the industrial revolution, most of them have long been rid of the strong dependence on "people": from raw material input to the output of the product, in the middle of a variety of precision instruments and automated assembly line of stable support, the real standardization of production and scale. Although information technology is called the third industrial revolution of mankind, but the current situation of the software industry, far from reaching the mature "industrialization" stage.
So, dear programmer friends, when you and the front-end interface for the morning, and the product tearing the afternoon demand, and then with their own bugs to fight a whole night, it is easy to disappear into the dream and was woken up by a series of alarm text messages, whether or not to raise his head to the starry sky longing for: "I have a dream... that one day, software development can also be used as a tool for the development of the software, but also for the production of the software, the software development of the software is not a dream. that one day, software development can also be like industrial products, batch production, stable and efficient no worries." Now, whether you realize it or not, this vision is slowly becoming a reality.
Please click to enter a description
Yes, low-code is industrializing the application development process: every low-code development platform is a technology-intensive application factory, with all project stakeholders working closely together on the same production line. The main developer is no longer a technical Geek who knows a hundred ways to write a for loop, but a group of application makers who are full of ideas and business sense. with the help of various mature infrastructures, ready-made standard parts, and automated assembly lines in the application factories, the developers only need to focus on the most core business value. Even if you encounter non-standard requirements, you can always do it yourself, with the most flexible hand-customized (code) to solve a variety of marginal problems.
Expanding the application development workforce
By allowing most development work to be done through simple drag-and-drop and configuration, low-code (including zero-code) significantly lowers the user threshold, allowing organizations to take full advantage of the civilian developer resources mentioned earlier. Part of the pure zero-code demand scenarios, low-code also allows business people to realize self-service (self-service) application delivery, not only to solve the traditional IT delivery model of the task backlog (backlog) problem, to avoid the scarce professional development resources by a large number of simple, repetitive application development needs, but also allows business people to really realize their own ideas to get rid of the application. It also allows business people to truly realize applications the way they want to, free from the shackles that inevitably come with leaving development to others.
Please click to enter image description
Thus, application development capability is no longer the patent and privilege of a few professional developers, and in the future, the required skill threshold and cost of ownership will become lower and lower, truly realizing the so-called "democratization of technology" (democratization of technology).
Strengthening the role of developers)
Strengthening communication and collaboration in the development process
Multiple surveys have shown that one of the main reasons for software project failure is a lack of communication (poor communication). Under the traditional development model, business, product, design, development, testing and operation and maintenance personnel have their own duties, and each has a set of tools and languages in the field, it is easy to form a "vertical well" (silos), so that cross-functional communication becomes difficult and inefficient. That's why Agile and DevOps emphasize communication (Biz and Dev in the former, Dev and Ops in the latter), and classic DDD advocates a "unified language" to reduce communication inconsistencies between business and technical staff.
Please click to enter a description
With low-code, this situation is radically improved: each of these roles can work closely together on the same low-code development platform (or even the same person), and this new model of collaboration not only breaks down the functional silos, but also makes it easy to align all project parties' understanding of the application form factor and logic with a unified visualization language and a single representation of the application (page/data/logic). align project parties' understanding of the application form and project schedule, enabling a more ultimate Agile development model, and BizDevOps [2], which is a step beyond traditional DevOps.
Convergence effects under a unified development platform
Low-code attempts to converge all activities related to application development onto one platform will generate more convergence effects and benefits of scale:
People convergence: In addition to the close collaboration of functional roles mentioned in the previous point, the convergence of people into a unified low-code development platform can also promote the development of a unified low-code development platform. Application aggregation: On the one hand, the architectural design of new applications, asset reuse, and mutual invocation become easier; on the other hand, the data of each application is naturally interoperable, and at the same time, off-platform data can also be passed through the integration capabilities, completely eliminating the problem of data silos in the enterprise. Ecological aggregation: When the low-code development platform aggregates enough developers and applications, it will form a huge, connected, infinitely imaginative ecosystem, completely releasing the value of low-code.