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:
Pretty section of content. I just stumbled upon your website and in accession capital to assert that I get actually enjoyed
account your blog posts. Anyway I will be subscribing to
your feeds and even I achievement you access consistently rapidly.
Thanks for sharing your thoughts on website. Regards
my web blog :: urb
Refresh Renovation Broomfield
11001 Ԝ 120tһ Ave 400 suite 459a,
Broomfield, СO 80021, United Ꮪtates
+13032681372
Extra for space additions home
Way cool! Some very valid points! I appreciate you writing this article and
the rest of the site is extremely good.
My spouse and I stumbled over here different website and thought
I should check things out. I like what I see so i am just following you.
Look forward to exploring your web page again.
My webpage; led display video
I have read some just right stuff here. Definitely
price bookmarking for revisiting. I wonder how much effort you place to create
this type of excellent informative site.