Low Code

Low Code

What is low-code? Low-code is a way to design and develop software applications fast and with minimal hand-coding. It enables skilled people to deliver value more quickly and more reliably. Using visual modeling in a graphical interface to assemble and configure applications, developers skip all the infrastructure and re-implementation of patterns that can bog them down and go straight to the unique 10% of an application.

Discover what you can build with a low-code application development platform 

What is Low-Code? Full-stack development with visual modeling

Low-code is analogous to manufacturing cars in some respects: most of what was once done by hand is now automated. The machines involved in the automation don’t decide what the car looks like, but they do accelerate the assembly and delivery process.

Low-code is to software what assembly lines are to the auto industry: both automate manual tasks that are difficult and time-consuming to free up people to do things that are much more important.

So, is there one answer to “what is low-code?”

No Really, What Is Low-code?

Okay, time to get away from analogies and down to the business of really answering “what is low-code?” In the software world, we rely on libraries, APIs and third-party infrastructure so that we can focus on delivering the unique bit of value that wouldn’t otherwise exist. But we still get bogged down.

Low-code describes a family of tools that helps developers create complete applications visually using a drag-and-drop interface. Rather than writing thousands of lines of complex code and syntax, low-code platforms allow users to build complete applications with modern user interfaces, integrations, data and logic quickly and visually.

Here’s what a typical low-code development platform looks like:

  • A visual IDE: An environment for visually defining the UI, workflows, and data models of your application and, where necessary, adding hand-written code.
  • Connectors to various back-ends or services: Automatically handles data structures, storage, and retrieval.
  • Application lifecycle manager: Automated tools to build, debug, deploy, and maintain the application in test, staging, and production.

Beyond those basics, no two low-code tools are exactly alike. Some are quite limited and more akin to a visual database front-end, like FoxPro in the 90s. Some focus on niche business needs, like case management. Others have adopted the low-code term to describe a purpose-built tool that has little to do with actual application development.

Others, such as OutSystems, give you everything you need to create modern, cross-platform enterprise mobile and web applications with capabilities that complement existing team structures.

What is Low-Code Back-End

What Is Low-code Like to Work With?

Fundamentally, building software with low-code is the same as building software any other way. Unless you’re writing everything from scratch in machine code—and, no, assembly language doesn’t count—then you’re already taking shortcuts built on the work of others.

With low-code, it’s all about the things you don’t have to do. Rather than hand-coding yet another user management system, dealing with the idiosyncrasies of the latest programming framework, or writing ten tests before a single line of your app’s code, you get straight to creating something new and valuable. Why start new when these problems have already been solved and the patterns are well understood?

Let’s compare creating an application using a common web framework to creating it using low-code.

The Traditional Application Development Process – Whether you’re working with .NET MVC, Spring Boot, or Ruby on Rails, you (and your team) go through roughly the same steps:

  1. Figure out the requirements.
  2. Plan the architecture.
  3. Select a back-end framework, some libraries, data stores and any third-party APIs.
  4. Select a front-end framework and hope it isn’t deprecated before you finish development.
  5. Choose your deployment stack, set up CI, create an operations plan.
  6. Create wireframes and prototypes.
  7. Hand code the UI in your chosen JavaScript framework.
  8. Write a bunch of failing tests.
  9. Define your models and hook them up to data stores.
  10. Define and then code your business logic,
  11. Create views that will provide and receive the necessary JSON data to or from the front-end.
  12. Implement your workflows and UI in your chosen front-end framework.
  13. Integrate third party APIs using their published interface or, if you’re lucky, a supported library in your chosen language.
  14. Repeat until the tests pass.
  15. Test for security, performance, quality and user acceptance.
  16. Deploy, patch, monitor, update until the application’s end of life.

The Low-Code Development Process – With low-code it would look more like this:

  1. Determine the requirements.
  2. Select any third-party APIs.
  3. Draw the app’s workflows, data models, and user interfaces in the visual IDE.
  4. Connect your APIs, usually with automatic capability discovery.
  5. If necessary, add any hand-code either to the front-end or to customize the automatically generated SQL queries.
  6. Test for user acceptance.
  7. Deploy to production, then push updates with a single click.

Seven steps instead of sixteen.

Low-code understands that most of the time spent hand-writing code in web and mobile apps is pretty much wheel spinning. There’s no need to tread the same path each time we start a new project. Low-code lets us create applications visually using battle-tested fundamentals. Our focus becomes delivering something valuable to the world.

Low-code Is About Getting More Done

Ultimately, low-code is a way for developers to get more done. With low-code, you spend more time creating and building and less time on repetitive work. Sure, it’s fun to learn the latest faddish JavaScript framework or play with a cutting-edge NoSQL data store, but while you’re spending time debugging unfamiliar code, your competitor has an MVP in front of customers.

Low-code isn’t about reducing the value of developers. Low-code lets teams of developers produce more value more quickly while drawing on their understanding of how to create and maintain high-quality web and mobile applications.

You can try low-code for yourself with OutSystems. Get started for free by following our tutorials to build web and cross-platform mobile apps in a fraction of the time you’re used to. You’ll also be able to help out the next person who asks, “What is low-code?”

Source: Outsystems Blog by Matt Revell