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:
Highly descriptive post, I liked that a lot. Will there be a part 2?
It’s actually a great and helpful piece of info.
I am glad that you shared this helpful info with us.
Please keep us informed like this. Thank you for sharing.
Good day I am so excited I found your webpage, I really found you by accident, while I was researching
on Aol for something else, Nonetheless I am here
now and would just like to say cheers for a fantastic post and a all round enjoyable blog (I
also love the theme/design), I don’t have time to read it all at the minute but I have bookmarked it and also added in your RSS feeds, so when I have time I will
be back to read more, Please do keep up the superb work.
단순한 상위 노출이 아닌, 고객의 니즈를
파악하고 연결하는 SEO 전략으로 검색을 ‘매출’로 바꾸는 마케팅을 실현합니다.
I am regular reader, how are you everybody? This post posted at this website is actually
pleasant.