If you're reading this article on a Web browser, you're experiencing the effects of code-on-demand. The whole Web runs on the premise that clients can

Why Aren’t APIs Using Code on Demand? - by Bruno Pedro

submited by
Style Pass
2025-01-17 14:30:10

If you're reading this article on a Web browser, you're experiencing the effects of code-on-demand. The whole Web runs on the premise that clients can not only request data but also code they then run to manipulate the information they receive. A common approach is to run JavaScript on the browser to provide users with a complete experience involving data and business logic. Why aren't APIs following a similar approach? Stay with me.

Further expanding its best-in-class API tooling, Speakeasy now empowers teams with open standards. The platform simplifies OpenAPI Overlay adoption so you can focus on building. Click the button below to check out the playground.

A few days ago, while doing some research for a project I'm working on, I ended up re-reading Roy Fielding's famous REST dissertation. However, this time, my eyes stopped when I read "code-on-demand." Not once, not twice, but a few times throughout the document. Fielding defends that code-on-demand offers "the ability to add features to a deployed client" offering better user-perceived performance. He makes code-on-demand one of the constraints of REST, albeit an optional one. According to the dissertation, code-on-demand "simplifies clients by reducing the number of features required to be pre-implemented." It looks like using code-on-demand is something everyone should be doing.

The notion of code-on-demand isn't something that Fielding came up with. As I wrote before, most Web applications rely on it to create the perception that interaction is local. Before that, every interaction was converted into a request sent back to the server. Web browsers would then render the response back to the user and wait for another interaction. The whole experience, from a user perspective, consisted of a series of requests with subsequent responses that eventually led to the rendering of a new Web page. And this is pretty much how REST APIs feel like today.

Leave a Comment