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:
I have read some good stuff here. Definitely price bookmarking
for revisiting. I surprise how so much effort you set to
make the sort of great informative web site.
Hurrah, that’s what I was exploring for, what a stuff!
existing here at this blog, thanks admin of this site.
Howdy! I know this is kind of off topic but I was wondering which blog platform
are you using for this website? I’m getting sick and tired of WordPress because I’ve had issues with hackers and I’m looking
at alternatives for another platform. I would be awesome if you
could point me in the direction of a good platform.
Thanks very interesting blog!