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:
Yes! Finally someone writes about bandar toto macau.
Peace of mind is priceless – thank you , ###this :# # anyKey word### , for keeping our family safe . commercial locksmith Orange County
Wow that was odd. I just wrote an very long comment but after I clicked submit my comment didn’t show up.
Grrrr… well I’m not writing all that over again. Anyhow, just wanted to say wonderful blog!
Hi to every one, it’s in fact a good for me to visit this site, it consists
of important Information.
Granules in the gutters? That’s a sign your shingles are aging. Getting quotes for replacement— kitchener roofing is on our shortlist.
Here is my blog post: high Stakes Poker
You need to take part in a contest for one of the
best blogs on the internet. I am going to recommend
this blog!