CoffeeScript lazy singleton class instance function

Explanation

“@instance:” allows us to attach an object/value to the Foo class instead of Foo’s prototype. Recall that “@” in CoffeeScript refers to JavaScript’s “this”.

After “@instance:” there is a function that is immediately executed. This function returns a function, closed around a variable called instance. Both these functions have their context (their “this”) bound to the Foo object using CoffeeScript’s wonderful “define and bind” operator “=>” as opposed to the normal function definition operator “->”.

When called, the function that “@instance” ends up referring to simply checks to see if the “instance” variable is empty and if so, assigns a new instance of Foo to it. Newing up a Foo is done using the “@” symbol since the function’s “this” refers to the Foo object. It then returns the instance.

Output

The CoffeeScript above compiles down to this:

23,235 thoughts on “CoffeeScript lazy singleton class instance function

  1. When I originally commented I clicked the “Notify me when new comments are added” checkbox and
    now each time a comment is added I get three emails with the same comment.
    Is there any way you can remove me from that service? Thank you!

  2. Hello i am kavin, its my first time to commenting anywhere,
    when i read this article i thought i could also create comment due to this brilliant piece of writing.

  3. hello there and thank you for your info – I have definitely picked up anything new
    from right here. I did however expertise a few technical issues using this site, as I experienced to reload the website lots of times previous to I could get it to load correctly.
    I had been wondering if your web hosting is OK?
    Not that I am complaining, but slow loading instances times will sometimes affect
    your placement in google and can damage your quality
    score if ads and marketing with Adwords. Anyway I am adding this RSS to my email and could look out for much more of your respective fascinating content.
    Ensure that you update this again soon.

  4. Nice post. I was checking constantly this blog
    and I am inspired! Extremely helpful information specifically the
    final part :) I maintain such info a lot. I used to be seeking this certain info for a very long
    time. Thanks and good luck.

  5. That is really fascinating, You are an excessively professional blogger.
    I’ve joined your rss feed and look forward to in quest of extra of your wonderful post.

    Additionally, I have shared your site in my social networks