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:
Amazing things here. I am very satisfied to look your article.
Thanks a lot and I’m having a look ahead to contact you.
Will you kindly drop me a e-mail?
It’s a shame you don’t have a donate button!
I’d without a doubt donate to this brilliant blog!
I guess for now i’ll settle for bookmarking and adding your
RSS feed to my Google account. I look forward to fresh updates and will share this blog with
my Facebook group. Talk soon!
Considering the importance of having reliable legal support in such cases, choosing a team like the San Diego personal injury lawyers can be crucial Police brutality lawyer