NodeJS: the beautiful callback err machine

One of the best things about NodeJS callbacks is their consistency. As in, most API calls require one and their method signature always follows the same pattern, and this is the most beautiful bit.

The first parameter of a callback is always an error object (which is null if no error occurred). This seems a little counterintuative at first. When you stop and think about it though, it really isn’t at all. My initial though was that most of the time, it isn’t going to be used, so why isn’t the result of the computation the first parameter? Well, that might be nice, but chances are you’re actually going to have to check to see if an error occurred first, before you start using your results, since if a error did occur, you probably don’t have any results anyway! Secondly, Node is cleverly reminding you that you should check for and deal with errors as they happen by ensuring you define a first parameter in order to define a second parameter to get at the stuff you want.

If the error was the second (or last) parameter the chances are you’d forget to define it, or the lazy would simply neglect to define it. This could happen because in JavaScript all parameters to functions are optional. Just because you do or don’t define parameters to a function, doesn’t mean you can’t call it with or without parameters. The function might not work in either of these cases, but nevertheless it is still possible to call it. It seems that by not coercing the programmer into defining an error parameter and dealing with it their code could become less robust.

The error parameter in the callback function is a necessity of asynchronous programming because errors cannot usually caught with a try/catch block as the execution of the callback function usually doesn’t happen in the block of code surrounded by the try/catch but instead in a later run of the event loop. I much prefer this way of dealing with errors as opposed to searching through my library code to find out if I even need to surround a function call in a try/catch by figuring out if it even does an operation that could possibly throw an error…and you know what, it’s future proof, because even if a function does no operations that could cause an error, it doesn’t mean that in a future version it won’t. By defining an error parameter from the start you can deal with a future mishap, now that is awesome.

19,171 thoughts on “NodeJS: the beautiful callback err machine

  1. Experience the best value in long-term parking at RDU. We offer competitive rates excellent customer service and a hassle-free parking experience. Book your spot today raleigh long term parking

  2. Are you thinking about a limo for your following getaway? It can make airport terminal transfers a lot easier and fashionable! Take a look at travel suggestions entailing limousines at uber limo

  3. Safeguarding futures rests heavily upon decisions made today—empower yourself take initiative consult knowledgeable individuals assisting navigate complexities surrounding situations requiring immediate attention dedicated professionals available willing accident injury lawyer

  4. Loved reading anecdotes highlighting passion-driven approaches taken by caregivers—they foster trust within therapeutic relationships which makes all difference – find supportive materials here: physical therapist

  5. Skup nieruchomości to idealna opcja dla tych, którzy potrzebują natychmiastowej gotówki za swoją nieruchomość. Dzięki temu procesowi można zaoszczędzić czas na poszukiwanie kupca i negocjacje cenowe skup domów

  6. I respect how some nursing buildings present personalized care plans adapted above all to every single resident’s needs—what a brilliant manner in Perth! aged care

Leave a Reply

Your email address will not be published. Required fields are marked *

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>