javascript에는 function statement와 function expression이 존재한다.
비슷하지만 약간의 차이가 난다.
<Function>
- function expression: var x = function fname(){} (fname is optional)
=> 이걸로 싱글턴 만들수 있다. class만들고 싱클턴 만드는 거 보다 less expensive.
- function statement: function fname(){}
<기타>
- javascript 에 {blocks} 는 scope을 가지지 않는다.
<슈도 파라미터 2가지>
- arguments : parameter와 밀접한 관계가 있으므로, read-only로 사용하는 게 좋다.
일종의 array로 최근(ES5)에 .reduce 등이 소개되었다.
arguments.length
arguments[i]
- this : function 내에서 멤버변수를위한 public 키워드처럼 동작하기도 하며, (이건 아래2번)
1. reference to the object of invocation.
2. allows to know the concerned Object
3. allows single function object to service many functions ?
4. key to prototype inheritance
Function.prototype.bind를 통해 this를 강제로 할당 할 수 있다.
<prototype이란>
All JavaScript objects inherit the properties and methods from their prototype.
Allows you to add properties and methods to an object
we can inherit using prototype. and by overriding construct(). => prototype is copied.
<function관련 Form종류들>
- New폼: new functionObject()
- function폼: functionObject(arg) 이 경우, var that = this; 많이 사용. inner function이 outer를 접근하기 위해서..
(왜냐면 자체 this가 있기 때문)
- method폼: functionObject(arg).method()
- apply폼: apply() form , 유사한것으로 call도 있는데, apply는 (this,array) call은 (this, a,b,c : each object of array)가 전달된다.
this 참고사이트: http://mobicon.tistory.com/189
유투브: 15분-this, 30분-closure (English)