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:
I don’t even know how I ended up here, but I thought this post was good.
Cheers!
I do not know who you are but definitely you’re going to a famous blogger if you
are not already
Cabinet IQ
15030 N Tatum Blvd #150, Phoenix,
AZ 85032, United Ѕtates
(480) 424-4866
Bespoke (Marie)
Good blog post. I definitely love this website.
Keep it up!
Great weblog here! Additionally your site lots up fast! What
host are you the use of? Can I get your affiliate link
on your host? I desire my web site loaded up as quickly as yours lol
If some one wants expert view concerning blogging and site-building
after that i recommend him/her to visit
this weblog, Keep up the good work.
This article is truly a good one it assists new the web people, who are wishing for blogging.
Thanks for sharing your thoughts about promotion. Regards
Hi there colleagues, nice post and fastidious urging commented at this place,
I am really enjoying by these.