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.

21,369 thoughts on “NodeJS: the beautiful callback err machine

  1. Ищете качественный кирпич напрямую от производителя? https://Muravey61.ru – ваш надежный поставщик строительных материалов в регионе Мы предлагаем кирпич высшего качества по доступным ценам прямо с завода. Доставка точно в срок широкий ассортимент и гарантированное качество – всё что нужно для вашего строительства. Закажите у нас и убедитесь сами что с нами строить легко

  2. Предлагаем услуги профессиональных инженеров офицальной мастерской. Еслли вы искали ремонт iphone 14 pro сервис можете посмотреть на сайте: ремонт iphone 14 pro Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом

  3. Я конечно прошу прощения но этот вариант мне не подходит. Оценить себя в олимпиадах стоит ребятам же с невысокими школьными оценками. часто такие онлайн площадки пропагандируют фирменные мастер классы по http://forexparty.org/analitica/novosti-foreks-industrii/intervyu-s-direktorom-instaforeks.html обучению.

  4. id=”firstHeading” class=”firstHeading mw-first-heading”>Search results

    Help

    English

    Tools

    Tools
    move to sidebar hide

    Actions

    General

  5. I appreciate your thoroughness when discussing local plumbing needs and options available! Found another site with awesome info regarding reputable plumbers in St cheap plumbers

  6. The fact that most warranties last decades when choosing quality materials like steel is encouraging—what warranties have people found most helpful over time? Discuss here or read warranty comparisons on my site: roofers in Vancouver area

  7. After looking over a number of the articles on your site, I truly like your way of blogging.
    I added it to my bookmark site list and will be checking back in the
    near future. Take a look at my web site too and
    tell me what you think.

    Feel free to surf to my web-site :: zaramea01

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>