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:
If some one wants expert view regarding blogging and
site-building afterward i advise him/her to visit
this blog, Keep up the pleasant job.
Wow! This blog looks just like my old one! It’s on a completely different topic but it has pretty much the same page layout and design. Wonderful
choice of colors!
Valuable information. Fortunate me I found your site unintentionally, and I am surprised why this accident didn’t happened
earlier! I bookmarked it.
Thanks for sharing your thoughts about sex.
Regards
It’s perfect time to make some plans for the long run and it’s time to be happy.
I’ve learn this submit and if I may I want to suggest you some
interesting issues or suggestions. Perhaps you can write next articles regarding this article.
I want to read more things about it!
Hello! Would you mind if I share your blog with my zynga group?
There’s a lot of folks that I think would really appreciate your content.
Please let me know. Cheers
Why people still use to read news papers when in this technological world
the whole thing is existing on web?