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:
That is very fascinating, You are an excessively skilled
blogger. I have joined your feed and sit up for seeking more of your wonderful post.
Additionally, I’ve shared your website in my social networks
Hello would you mind letting me know which hosting company
you’re utilizing? I’ve loaded your blog in 3 different web browsers and I must say this blog loads a lot faster then most.
Can you recommend a good web hosting provider at a honest price?
Thanks, I appreciate it!
I like what you guys are up too. This type of
clever work and coverage! Keep up the fantastic works guys I’ve added you guys
to blogroll.