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:
It’s an awesome post in support of all the online users; they will obtain benefit from it I am sure.
What’s up, I wish for to subscribe for this webpage to obtain latest updates, thus where can i do
it please help out.
excellent post, very informative. I’m wondering why the
opposite specialists of this sector don’t realize this. You should proceed
your writing. I’m sure, you have a great readers’ base already!
After exploring a handful of the blog posts on your web page, I truly appreciate
your technique of writing a blog. I added it to my bookmark
website list and will be checking back in the near future.
Please check out my website as well and tell me how you feel.
Hi there Dear, are you in fact visiting this site regularly,
if so afterward you will definitely take good know-how.