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,212 thoughts on “NodeJS: the beautiful callback err machine

  1. I find that utilizing multi-motive cleaners streamlines my efforts enormously—what items yield related effects while implemented creatively towards initiatives we embark upon together having enticing conversations surrounding topics protected within posts commercial cleaners

  2. Я извиняюсь но по-моему Вы ошибаетесь. Могу это доказать. Пишите мне в PM пообщаемся. Соблюдаем условия работе. загляните по адресу и просмотрите наши контакты будьте уверены http://noginsk-service.ru/forum/index.php?action=go;url=aHR0cDovL3d3dy50anN0cml6a292LmN6L3N0b2xuaS10ZW5pcy8yMi1ha3R1YWxpdGEtcGluZ3BvbmctMQ партнерство с нашей компанией оставит только самые приятные ощущения

  3. I discovered the data supplied in this put up about pet keep an eye on throughout backyard pursuits very valuable. It’s critical to ascertain our pets’ defense when still allowing them to delight in the outside Pest Control Kamloops

  4. купить диплом техникума в спб купить диплом техникума в спб .

  5. Believe me when say seeking professionals willing lend support invaluable asset anyone navigating complexities involved herein overall experiences felt firsth gum grafts

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>