{"data":{"site":{"siteMetadata":{"title":"lastrites2018","author":"lastrites2018","siteUrl":"https://lastrites2018.netlify.com","comment":{"disqusShortName":"","utterances":"lastrites2018/gatsby-first-blog"},"sponsor":{"buyMeACoffeeId":""}}},"markdownRemark":{"id":"4264dc87-5476-5954-86dc-ff79aea66304","excerpt":"복습 this this는 어떻게 바인딩되느냐에 따라 값이 달라진다. 이 내용은 꼭 외워야 한다. 5 Patterns of Binding ‘this’ Global : window Function : window 펑션 안에서 괄호 닫고 열고로 호출해도 window 일반적인 function 호출 : 값은 window 전역을 대표하는 변수가 window Method 호출 : 부모 object Construction mode (new 연산자로 생성된 function 영역의 this…","html":"<h1 id=\"복습-this\"><a href=\"#%EB%B3%B5%EC%8A%B5-this\" aria-label=\"복습 this permalink\" class=\"anchor\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>복습 this</h1>\n<p>this는 어떻게 바인딩되느냐에 따라 값이 달라진다.</p>\n<p>이 내용은 꼭 외워야 한다.</p>\n<h2 id=\"5-patterns-of-binding-this\"><a href=\"#5-patterns-of-binding-this\" aria-label=\"5 patterns of binding this permalink\" class=\"anchor\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>5 Patterns of Binding ‘this’</h2>\n<ol>\n<li>Global : window</li>\n<li>Function : window</li>\n</ol>\n<p>펑션 안에서 괄호 닫고 열고로 호출해도 window</p>\n<div class=\"gatsby-highlight\" data-language=\"javascript\"><pre class=\"language-javascript\"><code class=\"language-javascript\"><span class=\"token number\">1.</span> Global Refrence\n<span class=\"token keyword\">var</span> name <span class=\"token operator\">=</span> <span class=\"token string\">'global Variable'</span><span class=\"token punctuation\">;</span>\nconsole<span class=\"token punctuation\">.</span><span class=\"token function\">log</span> <span class=\"token punctuation\">(</span><span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>name<span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span> <span class=\"token comment\">//Global Variable : window</span>\n\n\n<span class=\"token number\">2.</span> <span class=\"token keyword\">function</span>\n<span class=\"token keyword\">function</span> <span class=\"token function\">foo</span> <span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n    console<span class=\"token punctuation\">.</span><span class=\"token function\">log</span><span class=\"token punctuation\">(</span><span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>name<span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span> <span class=\"token comment\">//Global Variable : window</span>\n<span class=\"token punctuation\">}</span>\n<span class=\"token function\">foo</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span> <span class=\"token operator\">-</span><span class=\"token operator\">></span> <span class=\"token comment\">// window!</span>\n    괄호 열고 닫고로 실행해도 window<span class=\"token operator\">!</span>\n\n       <span class=\"token keyword\">function</span> <span class=\"token function\">outer</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n        <span class=\"token keyword\">function</span> <span class=\"token function\">inner</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n            console<span class=\"token punctuation\">.</span><span class=\"token function\">log</span><span class=\"token punctuation\">(</span><span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>name<span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span>\n        <span class=\"token punctuation\">}</span>\n    <span class=\"token punctuation\">}</span>\n        <span class=\"token function\">outer</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token operator\">-</span><span class=\"token operator\">></span> 여기도 마찬가지로 window\n\n        <span class=\"token keyword\">this</span>의 바인딩은 scope와 상관 없다</code></pre></div>\n<p>일반적인 function 호출 : 값은 window</p>\n<p>전역을 대표하는 변수가 window</p>\n<ol start=\"3\">\n<li>Method 호출 : 부모 object</li>\n</ol>\n<div class=\"gatsby-highlight\" data-language=\"javascript\"><pre class=\"language-javascript\"><code class=\"language-javascript\"><span class=\"token keyword\">var</span> counter <span class=\"token operator\">-</span> <span class=\"token punctuation\">{</span>\n    val<span class=\"token punctuation\">:</span> <span class=\"token number\">0</span><span class=\"token punctuation\">,</span>\n    increment<span class=\"token punctuation\">:</span> <span class=\"token keyword\">function</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n        <span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>val <span class=\"token operator\">+=</span> <span class=\"token number\">1</span><span class=\"token punctuation\">;</span>\n        <span class=\"token comment\">// counter.val과 동일</span>\n        <span class=\"token comment\">// 부모 오브젝트를 뜻함.</span>\n    <span class=\"token punctuation\">}</span>\n<span class=\"token punctuation\">}</span>\ncounter<span class=\"token punctuation\">.</span><span class=\"token function\">increment</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span>\nconsole<span class=\"token punctuation\">.</span><span class=\"token function\">log</span><span class=\"token punctuation\">(</span>counter<span class=\"token punctuation\">.</span>val<span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span> <span class=\"token comment\">// 1</span>\ncounter<span class=\"token punctuation\">[</span><span class=\"token string\">'increment'</span><span class=\"token punctuation\">]</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span>\nconsole<span class=\"token punctuation\">.</span><span class=\"token function\">log</span><span class=\"token punctuation\">(</span>counter<span class=\"token punctuation\">.</span>val<span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span> <span class=\"token comment\">// 2</span>\n\n\n<span class=\"token keyword\">var</span> obj <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span>\n    fn<span class=\"token punctuation\">:</span> <span class=\"token keyword\">function</span><span class=\"token punctuation\">(</span>a<span class=\"token punctuation\">,</span>b<span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n        <span class=\"token keyword\">return</span> <span class=\"token keyword\">this</span><span class=\"token punctuation\">;</span>\n    <span class=\"token punctuation\">}</span>\n<span class=\"token punctuation\">}</span><span class=\"token punctuation\">;</span>\n<span class=\"token keyword\">var</span> obj2 <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span>\n    method<span class=\"token punctuation\">:</span> obj<span class=\"token punctuation\">.</span>fn\n    <span class=\"token comment\">// 레퍼런스를 카피한다고 생각하면 된다.</span>\n    <span class=\"token comment\">// copy by refrence</span>\n    <span class=\"token comment\">// 위의 내용을 그대로 가져온다고 생각.</span>\n<span class=\"token punctuation\">}</span>\n\n<span class=\"token comment\">// 이거 헷갈릴 수 있지만, true다!</span>\nobj2<span class=\"token punctuation\">.</span><span class=\"token function\">method</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token operator\">===</span> obj2 <span class=\"token comment\">// true</span>\nobj<span class=\"token punctuation\">.</span><span class=\"token function\">fn</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token operator\">===</span> obj <span class=\"token comment\">// true</span></code></pre></div>\n<ol start=\"4\">\n<li>\n<p>Construction mode (new 연산자로 생성된 function 영역의 this)</p>\n<p>: 새로 생성된 객체</p>\n<p>-> ES6에서 클래스 개념 도입. ES5까진 없었음.</p>\n<p>컨스트럭션 모드가 클래스 형식.</p>\n<div class=\"gatsby-highlight\" data-language=\"javascript\"><pre class=\"language-javascript\"><code class=\"language-javascript\"><span class=\"token keyword\">function</span> <span class=\"token function\">Car</span><span class=\"token punctuation\">(</span>name<span class=\"token punctuation\">,</span> brand<span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n <span class=\"token comment\">// 대문자로 시작하는 이유가 클래스로 시작한다는 컨벤션</span>\n <span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>name <span class=\"token operator\">=</span> name\n <span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>brand <span class=\"token operator\">=</span> brand\n<span class=\"token punctuation\">}</span>\n<span class=\"token keyword\">var</span> avante <span class=\"token operator\">=</span> <span class=\"token keyword\">new</span> <span class=\"token class-name\">Car</span><span class=\"token punctuation\">(</span><span class=\"token string\">'avante'</span><span class=\"token punctuation\">,</span> <span class=\"token string\">'hyundai'</span><span class=\"token punctuation\">)</span>\n<span class=\"token comment\">//인스턴스를 만드는 과정 avante와 car720d과 인스턴스</span>\n<span class=\"token comment\">//avante는 껍데기기</span>\n\navante<span class=\"token punctuation\">.</span>brand\navante<span class=\"token punctuation\">.</span>name\n\n<span class=\"token keyword\">var</span> car720d <span class=\"token operator\">=</span> <span class=\"token keyword\">new</span> <span class=\"token class-name\">car</span><span class=\"token punctuation\">(</span><span class=\"token string\">'720d'</span><span class=\"token punctuation\">,</span> <span class=\"token string\">'bmw'</span><span class=\"token punctuation\">)</span>\n\n<span class=\"token keyword\">function</span> <span class=\"token function\">Human</span><span class=\"token punctuation\">(</span>name<span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n <span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>name <span class=\"token operator\">=</span> name\n<span class=\"token punctuation\">}</span>\n\n<span class=\"token keyword\">function</span> <span class=\"token function\">Human</span><span class=\"token punctuation\">(</span>name<span class=\"token punctuation\">,</span> age<span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n <span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>name <span class=\"token operator\">=</span> name\n <span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>age <span class=\"token operator\">=</span> age\n <span class=\"token keyword\">debugger</span> <span class=\"token comment\">// 실행해보기</span>\n<span class=\"token punctuation\">}</span>\n<span class=\"token keyword\">var</span> hoyong <span class=\"token operator\">=</span> <span class=\"token keyword\">new</span> <span class=\"token class-name\">Human</span><span class=\"token punctuation\">(</span><span class=\"token string\">'hoyong'</span><span class=\"token punctuation\">,</span> <span class=\"token number\">400</span><span class=\"token punctuation\">)</span>\n<span class=\"token comment\">//new 키워드를 쓰는게 object를 바탕으로 construct 한다는 것</span>\nhoyong<span class=\"token punctuation\">.</span>name\nhoyong<span class=\"token punctuation\">.</span>age\n\n<span class=\"token comment\">//정의된 함수를 껍데기로 삼아서 새로운 것을 만드는 것</span>\n\n<span class=\"token keyword\">function</span> <span class=\"token constant\">F</span><span class=\"token punctuation\">(</span>v<span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n <span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>val\n <span class=\"token comment\">// 이 this가 무엇을 가리키냐가 중요한 개념,</span>\n <span class=\"token comment\">// 이때의 this는 새로 생성된 개념.</span>\n<span class=\"token punctuation\">}</span>\n\n<span class=\"token keyword\">var</span> f <span class=\"token operator\">=</span> <span class=\"token keyword\">new</span> <span class=\"token class-name\">F</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span>\n<span class=\"token comment\">//이 this는 small f</span>\n\n<span class=\"token comment\">//new car() -> 인스턴스를 만드는 과정</span></code></pre></div>\n</li>\n</ol>\n<p>Objected Orient Programming 객체 지향 프로그래밍 : 추상화를 시켜서</p>\n<ol start=\"5\">\n<li>\n<p>.call or .apply 호출 : call, apply의 첫번째 인자로 명시 된 객체</p>\n<div class=\"gatsby-highlight\" data-language=\"javascript\"><pre class=\"language-javascript\"><code class=\"language-javascript\"><span class=\"token keyword\">function</span> <span class=\"token function\">identify</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n <span class=\"token keyword\">return</span> <span class=\"token keyword\">this</span><span class=\"token punctuation\">.</span>name<span class=\"token punctuation\">.</span><span class=\"token function\">toUpperCase</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span>\n<span class=\"token punctuation\">}</span>\n<span class=\"token keyword\">function</span> <span class=\"token function\">speak</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n <span class=\"token keyword\">var</span> greeting <span class=\"token operator\">=</span> <span class=\"token string\">\"Hello, I'm\"</span> <span class=\"token operator\">+</span> identify<span class=\"token punctuation\">.</span><span class=\"token function\">call</span><span class=\"token punctuation\">(</span><span class=\"token keyword\">this</span><span class=\"token punctuation\">)</span>\n console<span class=\"token punctuation\">.</span><span class=\"token function\">log</span><span class=\"token punctuation\">(</span>greeting<span class=\"token punctuation\">)</span>\n<span class=\"token punctuation\">}</span>\n<span class=\"token keyword\">var</span> me <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span> name<span class=\"token punctuation\">:</span> <span class=\"token string\">'Kyle'</span> <span class=\"token punctuation\">}</span>\n<span class=\"token keyword\">var</span> you <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span> name<span class=\"token punctuation\">:</span> <span class=\"token string\">'Reader'</span> <span class=\"token punctuation\">}</span>\n\n<span class=\"token comment\">//this를 명시적으로 넘겨주기 위해</span>\n<span class=\"token comment\">//call</span>\n<span class=\"token comment\">//apply(배열)</span>\n\nidentify<span class=\"token punctuation\">.</span><span class=\"token function\">me</span><span class=\"token punctuation\">(</span><span class=\"token keyword\">this</span><span class=\"token punctuation\">)</span>\nidentify<span class=\"token punctuation\">.</span><span class=\"token function\">call</span><span class=\"token punctuation\">(</span>me<span class=\"token punctuation\">)</span> <span class=\"token comment\">//KYLE</span>\nidentify<span class=\"token punctuation\">.</span><span class=\"token function\">call</span><span class=\"token punctuation\">(</span>you<span class=\"token punctuation\">)</span> <span class=\"token comment\">//READER</span>\nspeak<span class=\"token punctuation\">.</span><span class=\"token function\">call</span><span class=\"token punctuation\">(</span>me<span class=\"token punctuation\">)</span> <span class=\"token comment\">// Hello, I'm KYLE</span>\nspeak<span class=\"token punctuation\">.</span><span class=\"token function\">clll</span><span class=\"token punctuation\">(</span>you<span class=\"token punctuation\">)</span> <span class=\"token comment\">// Hello, I'm READER</span>\n<span class=\"token comment\">// 이럴 경우 전역에 있는 name에 접근</span>\n\n<span class=\"token comment\">// 색으로 구분된 this 자료 찾아보기!!</span>\n<span class=\"token comment\">// 해보면서 해석해보기</span></code></pre></div>\n</li>\n</ol>","frontmatter":{"title":"this review - 5 Patterns of Binding this","date":"August 07, 2018"}}},"pageContext":{"isCreatedByStatefulCreatePages":false,"slug":"/til/20180807 this review - 5 Patterns of Binding this/","previous":{"fields":{"slug":"/til/20180807 Complexity/"},"frontmatter":{"title":"Complexity","category":"TIL"}},"next":{"fields":{"slug":"/til/20180809 Precourse Last Week + this, call, apply bind review/"},"frontmatter":{"title":"Precourse Last Week + this, call, apply bind review","category":"TIL"}}}}