2012-11-02

Back from Callback Hell with Bacon.js


I've heard the words Callback Hell quite a many times lately. I'll take it that you know what I'm talking about. Just gonna briefly show how to get Back from Hell with bacon.js...
So, what about if you want to perform two independent AJAX calls and do something with the values of both? You might
$.ajax("/cats").done(function(cats) {
  $.ajax("/dogs").done(function(dogs) {
    doStuffWithCatsAndDogs(cats, dogs)
  })
})
That's a minor callback hell allready. How about
var cats = Bacon.fromPromise($.ajax("/cats")
var dogs = Bacon.fromPromise($.ajax("/dogs")
Bacon.combineAsArray(cats, dogs).onValues(doStuffWithCatsAndDogs)
Know what? Your AJAX just got parallel, too. Maybe we should refactor this too:
function ajax(url) { return Bacon.fromPromise($.ajax(url)) }
Bacon.combineAsArray(ajax("/cats"), ajax("/dogs")).onValues(doStuffWithCatsAndDogs)
That's it.
Now if you wanted both cats and dogs and then do something with both and something based on an AJAX query triggered by user input... You would do
$.ajax("/cats").done(function(cats) {
  $.ajax("/dogs").done(function(dogs) {
    $("input.name").onKeyUp(function() {
      $.ajax("/stuff/" + $("input.name").val()).done(function(stuff) {
        var allTheStuff = {
          cats: cats,
          dogs: dogs,
          stuff: stuff
        }
        doStuff(allTheStuff)
      })
    })
  })
})
That's some serious callback hell. See any problems? For one, the user input won't be captured until both AJAX calls (cats, dogs) are completed, and they are not done in parallel, either. Further, the AJAX calls triggered by user input do not necessarily return in the same order as they are issued, so the last call to "doStuff" might be based on stale data. That might prove hard to fix?
With Bacon, you could do
function ajax(url) { return Bacon.fromPromise($.ajax(url)) }
function urlForStuff(name) { return "/stuff/" + name }

var name = Bacon.UI.textFieldValue($("input.name"))

Bacon.combineTemplate({
  cats: ajax("/cats"),
  dogs: ajax("/dogs",
  stuff: name.map(urlForStuff).ajax()
}).onValue(doStuff)
Now you'll start capturing user input immediately. Your initial AJAX calls are executed in parallel and combined with the latest value returned by the "/stuff/*" AJAX when all values are available.
And the ".ajax()" call actually ensures that the results are based on latest user input.

11 comments:

  1. Could you provide the .ajax() implementation?

    ReplyDelete
    Replies
    1. Masse, https://github.com/raimohanska/Bacon.UI.js

      Sorry for the delay :( The amount of spam makes it a bit hard to monitor real comments on Blogspot.

      Delete
  2. I love bacon, but I don't think the comparison to promises are fair.

    In your example, you are using promises as if they are callbacks. Using promises that way defeats the purposes of promises.

    asyncOp1()
    .then(async2)
    .then(async3)
    .then(async4, logFailure);

    The other thing I think the post missed is how great promises are for dealing with parallel code. Here's an example:

    doStuff = $.when(getCats, getDogs, getStuff).then(getDoStuff);


    Both Bacon and promises offer similar control flow structures, so either way is okay by me, but I don't think you gave promises a fair shake.

    Btw, I love your blog, your earlier posts on Bacon convinced me to use it in my next application.

    ReplyDelete
    Replies
    1. You're absolutely right regarding Promises. Promises indeed provide a very similar interface to Bacon.js streams and allow you to compose data from asynchronous sources in a nice way.

      What I didn't know was that you can use $.when() to compose parallel promises like that.

      The main difference between Promises and EventStreams is that the latter may contain multiple values over time. For many applications (including AJAX), they provide roughly equivalent power of expression.

      And my apologies for the delay.

      Delete
  3. Nice looking sites and great work. Pretty nice information. it has a better understanding. thanks for spending time on it.


    Hadoop Training Institute in Noida

    Best Hadoop Training in Noida

    ReplyDelete
  4. Your post is very good. I got to learn a lot from your post. Thank you for sharing your article for us. it is amazing post
    what is seo
    types of seo


    ReplyDelete
  5. مكيف الهواء الخاص بك هو واحد من أهم الاجهزه الخاصة بك (ومكلفه) في منزلك. من الصعب تخيل الحياة بدون هذه في سياراتنا ومكاتبنا ومنازلنا... كنت اسمه! مع ذلك ، من المهم ان نبذل كل ما في وسعنا للتاكد من ان مكيفات الهواء لدينا تستمر لفتره طويلة وأداء فعال. بالطبع هناك أشياء يجب عليك القيام بها ، ولكن ماذا لا ينبغي ان تفعل ؟
    شركة تنظيف مكيفات فى رياض الخبراء
    شركة تنظيف مكيفات بالبكيرية
    شركة تنظيف مكيفات بعنيزة
    شركة تنظيف مكيفات ببريدة
    شركة تنظيف مكيفات بالقصيم

    وهنا أربعه أشياء يجب ان لا تفعل إذا كنت تريد مكيف الهواء الخاص بك للحفاظ علي تشغيل بسلاسة وكفاءه.

    لا تزرع أبدا في غضون قدمين من المكثف الخاص بك. تدفق الهواء المحظور هو الرهيبة لكفاءة جهاز التكييف الخاص بك. السماح دائما التخليص السليم بين المكثف الخاص بك والنباتات الخاصة بك.
    لا تستخدم أبدا السجلات أو الفتحات أو الأبواب للتحكم في درجه حرارة الغرفة بالغرفة. مكيف الهواء الخاص بك هو الحجم لتبريد لقطات مربع معينه. إذا كنت تريد السيطرة علي غرفه بغرفه ، والنظر في نظام تقسيم المناطق. خذ غطاء مكيف الهواء الخاص بك من وحدتك قبل بدء موسم التبريد.
    أبدا السلطة يغسل مكيف الهواء الخاص بك. علي الرغم من ان هناك طرق يمكنك تنظيف مكيف الهواء الخاص بك ، يجب ان غسالة الطاقة أبدا ان يكون واحدا منهم. يمكن ان تسبب هذه الاضرار للفائف الخاص بك ويؤدي إلى انهيار النظام. جدوله موعد تنظيف مكثف مع الرجل المحلية.
    فنى صيانة مكيفات سبليت بالرياض
    ارقام صيانة مكيفات سبليت بالرياض
    شركة صيانة مكيفات بالرياض
    شركة تنظيف مكيفات سبليت بالرياض
    شركة تنظيف مكيفات الاسبلت بالرياض عمالة فلبينية

    أبدا محاولة لتشخيص مشاكل مع مكيف الهواء الخاص بك بنفسك. مكيفات الهواء ليست مناسبه أبدا للحلول DIY ، أبدا. اتصل دائما بالمقاول
    شيء واحد يجب ان تفعل دائما لمكيف الهواء الخاص بك هو جدول الصيانة الوقائية الربيع مع التدفئة المحلية الخاصة بك والمقاول تكييف الهواء.
    ما هي بعض النصائح لتكييف الهواء الخاص بك ؟ هل هناك أشياء أخرى تود معرفتها عن مكيفات الهواء ؟

    ReplyDelete
  6. شركة مكافحة حشرات بالخبر

    tuetabar eamaliaat albahth ean sharikat mukafahat hasharat bialkhabar min 'akthar al'ashya' alati taqum biha taqum biha almamlakat almutahidat mae dukhul fasl alsayfi.
    wamin almaeruf 'ana altaayirat almaerufat biaism altaayirat wahataa alnaml wabaq , wamusaeadatihim , wazuhurihim mae ziadat darajat alhararati.

    شركة مكافحة الحمام بالخبر

    sharikat mukafahat hamaam bialkhabar bialkhabar walkhabar min al'ashya' alati yabhath eanha aleumala' fi alkhabar , wadhalik min 'ajl alhusul ealaa jawazat safar wafidat min altuyur , tuafir mkanan fi mintaqat alkaram alhadithat waltaqniaat min 'ajl tilk alsuwrat waltilialiat fi tilk al'anwae min altibaei. altaaqat alati tama tarkibuha ealaa kafat alhafalat , waltaaqat , waltaaqat , waltaaqat , waltaaqat alkahrabayiyat , wakadhalik altaaqat alkahrabayiyatu.

    شركة تنظيف مكيفات بالخبر

    sharikat tanzif mukayifat bialkhabar taqum bikuli 'aemal altanzif ealaa 'akmaliha ladayha khibrat wakafayh ealyh fi hadha almajal , walkitabat fi jawlat fi alfaragh 'iinama bialtarkiz lilwusul 'iilaa 'aelaa darajat fi aldarajat al'uwlaa , kama tahtamu .
    bisabab airtifae darajat alhararat alshadidat , fa'iina kathrat aistikhdam almukayifat wakathrat taearudiha lilkharij alkharijii yaeriduha dakhil almukayif wadukhul 'iilaa alkharij , wahadha yadulu ealaa 'ana jamie 'afrad hadhih al'aemal yaemalun fi 'aemal altanzifi. khibratan khasatan mae sharikat khibrat ealiat mithl sharika

    شركة تعقيم بالخبر

    taeqim bialdamaam , waltibaeat waltaeqim , waltibaeat , waltibaeat , waltibaeat , waltibaeat , waltibaeat , waltibaeat , waltibaeat , waltibaeat , waltibaeat li sharikat altaeqim waealaa rasiha sharikat taeqim bialdamaam alati tamtalik khtwtan taemal fi alkharij fi alhifaz ealaa alsihat aleamati.

    شركة تسليك مجاري بالخبر

    sharikat taslik majari bialqatif sharikat altatwir aleaqarii fi almustaqbal bialqatif min akhtur almashakil alati qad tuajihuk natijatan lisababih min nawe sababuh min alsabab wara' dhalik lilmanzil walilhamaamat walmatabikh alkhasat bialmanzil wamushkilat ainsidad almajari 'aw alsirf alsihiyi 'aw ainsidad

    شركة تنظيف منازل بالخبر

    sharikat tanzif manazil bialkhabar tastakhdim afdal turuq albaye aldaakhilii lilmanazil bialkharij bialaietimad ealaa aleamalat dhat aleamalat alkabirat fi tanfidh kafat aemaal tanzif almanazil w alkhadamat
    wasaead fi alhusul ealaa mujtamae watiib , wabiyat , wabiyat , wabiyat , wataeam , wanas tawal alwaqt

    ReplyDelete