Skip to content

Latest commit

 

History

History
58 lines (37 loc) · 2.98 KB

README.md

File metadata and controls

58 lines (37 loc) · 2.98 KB

API-less

API-Less Architecture

Most modern applications (single-page web apps, mobile apps, etc.) consist of two parts:

  • A frontend to manage the user interface.
  • A backend to manage business logic and data storage.

To connect the frontend and the backend, a web API (REST, GraphQL, etc.) is generally used, which requires the development of an API client on the frontend side and an API server on the backend side.

We have the following architecture:

Typical architecture

With an API-less architecture, the frontend can communicate with the backend without the need to build a web API. The backend exposes functions (or methods) that the frontend can call directly, and the developer no longer has to worry about URL paths, HTTP methods, or status codes.

Of course, since the frontend and the backend run in separate environments, there is necessarily an API client and an API server in between, but they are no longer the responsibility of the developer. The API layers are handled by a library or a framework.

So an API-less architecture looks like this:

Typical architecture

Removing the API layers not only reduces the amount of code the developer has to write, it also improves quality by reducing code scattering and duplication of knowledge.

Libraries and Frameworks

A growing number of libraries and frameworks allow to implement the API-less architecture.

JavaScript/TypeScript

Product Product type API type Real time Mobile support Since
Meteor Framework Procedural Yes Yes 2012
Layr Library Object-oriented On the roadmap Yes 2019
Blitz.js Framework Procedural No On the roadmap 2020
tRPC Library Procedural In beta Yes 2021
Telefunc Library Procedural On the roadmap Yes 2021

Contributing

Contributions are welcome.

Before contributing please read the code of conduct and search the issue tracker to find out if your issue has already been discussed before.

To contribute, fork this repository, commit your changes, and send a pull request.

License

MIT