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:
Excellent weblog here! Also your website lots up fast! What web host are you the use of?
Can I am getting your associate hyperlink to your host?
I wish my site loaded up as fast as yours lol
Woah! I’m really enjoying the template/theme of this site.
It’s simple, yet effective. A lot of times it’s tough to get that “perfect balance” between superb
usability and visual appearance. I must say that you’ve done a awesome job with this.
Additionally, the blog loads super fast for me on Firefox. Superb Blog!
I like the valuable information you provide in your articles.
I will bookmark your blog and check again here regularly.
I am quite certain I’ll learn plenty of new stuff right here!
Best of luck for the next!
If you desire to get a good deal from this piece
of writing then you have to apply these methods to your won website.