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:
Hello, i think that i saw you visited my website thus i came to “return the favor”.I’m attempting to find things to improve
my site!I suppose its ok to use some of your ideas!!
Review my blog :: Das verbotene Klassenzimmer
Hi Dear, are you actually visiting this web site on a regular basis,
if so after that you will without doubt get fastidious experience.
This design is spectacular! You most certainly know how to keep a reader entertained.
Between your wit and your videos, I was almost moved to start my own blog (well, almost…HaHa!)
Excellent job. I really loved what you had to say, and more than that,
how you presented it. Too cool!
В этой статье вы найдете уникальные исторические пересечения с научными открытиями. Каждый абзац — это шаг к пониманию того, как наука и события прошлого создают основу для технологического будущего.
Продолжить изучение – http://spsos.wtzsroda.pl/tlosos-2