250x250
Rainbow๐ŸŒˆCoder
My dev Note๐Ÿ“’
Rainbow๐ŸŒˆCoder
์ „์ฒด ๋ฐฉ๋ฌธ์ž
์˜ค๋Š˜
์–ด์ œ
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (411)
    • ๊ณต์ง€์‚ฌํ•ญ (0)
    • Debugger (10)
      • Visual Studio Debugger (1)
      • Chrome DevTools (3)
      • Visual Studio Code Debugger (4)
      • eclipse (1)
      • intelliJ (1)
    • OOP (2)
      • OOP (2)
    • TypeScript (54)
      • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript (54)
    • Javascript (87)
      • Javascript (45)
      • Node.js (19)
      • React (5)
      • FE ๊ฐœ๋ฐœํ™˜๊ฒฝ์„ค์ • (3)
      • React์™€ Node ๊ฐ™์ด ๋•Œ๋ ค์žก๊ธฐ (6)
      • next.js (2)
      • pixi.js (7)
    • ๋งˆํฌ์—… (23)
      • Html & Css (23)
    • C# (80)
      • C# (12)
      • ์ด๊ฒƒ์ด C#์ด๋‹ค (68)
    • C++ (30)
      • c++ (27)
      • win api (3)
    • Unity (18)
      • Unity(๊ธฐ์ดˆ) (8)
      • Unity(C#์ค‘๊ธ‰) (5)
      • ์œ ๋‹ˆํ‹ฐ ํฌํ†ค(๋„คํŠธ์›Œํฌ) (4)
      • unity c# MyCode (1)
    • Java & Spring (29)
      • Java (11)
      • ์Šคํ”„๋ง (8)
      • Java Algorithm (9)
      • Javs Data Structures (1)
    • ์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (15)
      • ์ž๋ฃŒ๊ตฌ์กฐ (5)
      • ์•Œ๊ณ ๋ฆฌ์ฆ˜ (10)
    • ํ˜•์ƒ๊ด€๋ฆฌ (15)
      • Git (11)
      • ์†Œ์ŠคํŠธ๋ฆฌ (3)
    • ๊ทธ๋ž˜ํ”ฝ์Šค (7)
      • WebGl (7)
    • AWS (3)
      • aws (3)
    • ๋ฆฌ๋ˆ…์Šค (5)
      • ๋ฆฌ๋ˆ…์Šค (5)
    • ์ฑ… ๋ฆฌ๋ทฐ (13)
      • ํด๋ฆฐ์ฝ”๋“œ(์ฑ…๋ฆฌ๋ทฐ) (3)
      • ์œ ์ง€๋ณด์ˆ˜๊ฐ€๋Šฅํ•œ์ฝ”๋”ฉ์˜๊ธฐ์ˆ C#ํŽธ(์ฑ…๋ฆฌ๋ทฐ) (1)
      • ๋ฆฌํŒฉํ† ๋ง(์ž๋ฐ”์Šคํฌ๋ฆฝํŠธํŒ) (9)
    • Server (2)
      • ๊ฒŒ์ž„ ์„œ๋ฒ„(๋„คํŠธ์›Œํฌ, ๋ฉ€ํ‹ฐ์“ฐ๋ ˆ๋“œ,OS) (2)
    • ์„ค๊ณ„, ์•„ํ‚คํ…์ณ (4)
    • ํŒŒ์ด์ฌ (5)
    • ๋””์ž์ธํŒจํ„ด (2)
    • mocha (2)
    • Jest (1)
    • Spine (1)
    • ์ธ๊ณต์ง€๋Šฅ (1)
      • ํ˜ผ์ž๊ณต๋ถ€ํ•˜๋Š”๋จธ์‹ ๋Ÿฌ๋‹+๋”ฅ๋Ÿฌ๋‹ (1)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

๊ณต์ง€์‚ฌํ•ญ

์ธ๊ธฐ ๊ธ€

ํƒœ๊ทธ

  • ์ปดํฌ์ง€์…˜
  • MySQL
  • ์œ„์ž„
  • ใ…ฃใ„ท

์ตœ๊ทผ ๋Œ“๊ธ€

์ตœ๊ทผ ๊ธ€

ํ‹ฐ์Šคํ† ๋ฆฌ

hELLO ยท Designed By ์ •์ƒ์šฐ.
Rainbow๐ŸŒˆCoder

My dev Note๐Ÿ“’

Javascript/Javascript

Bind

2022. 7. 19. 01:37
728x90

 

this.x = 9;
var module = {
  x: 81,
  getX: function() { return this.x; }
};

module.getX(); // 81

var retrieveX = module.getX;
retrieveX();
// 9 ๋ฐ˜ํ™˜ - ํ•จ์ˆ˜๊ฐ€ ์ „์—ญ ์Šค์ฝ”ํ”„์—์„œ ํ˜ธ์ถœ๋์Œ

// module๊ณผ ๋ฐ”์ธ๋”ฉ๋œ 'this'๊ฐ€ ์žˆ๋Š” ์ƒˆ๋กœ์šด ํ•จ์ˆ˜ ์ƒ์„ฑ
// ์‹ ์ž… ํ”„๋กœ๊ทธ๋ž˜๋จธ๋Š” ์ „์—ญ ๋ณ€์ˆ˜ x์™€
// module์˜ ์†์„ฑ x๋ฅผ ํ˜ผ๋™ํ•  ์ˆ˜ ์žˆ์Œ
var boundGetX = retrieveX.bind(module);
boundGetX(); // 81
this.name ='์†Œ๋ƒ';
let person1 = {
    name: '์•„๋ฌด๋ฌด'
};

let person2 = {
    name: '๋Ÿญ์Šค',
    study: function() {
        console.log(this.name + '์ด/๊ฐ€ ๊ณต๋ถ€๋ฅผ ํ•˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค.');
    }
};

person2.study(); // ๋Ÿญ์Šค์ด/๊ฐ€ ๊ณต๋ถ€๋ฅผ ํ•˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค.

let fullStudy = person2.study;
fullStudy(); //์†Œ๋ƒ์ด/๊ฐ€ ๊ณต๋ถ€๋ฅผ ํ•˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค.

// bind()
let student = person2.study.bind(person1);

student(); // ์•„๋ฌด๋ฌด์ด/๊ฐ€ ๊ณต๋ถ€๋ฅผ ํ•˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค.

 

Bind


func.bind(thisArg[, arg1[, arg2[, ...]]])

  1. thisArg: ๋ฐ”์ธ๋”ฉ ํ•จ์ˆ˜๊ฐ€ ํƒ€๊ฒŸ ํ•จ์ˆ˜์˜ this์— ์ „๋‹ฌํ•˜๋Š” ๊ฐ’
  2. arg1, arg2, … : func์ด ํ˜ธ์ถœ๋˜์–ด์•ผ ํ•˜๋Š” ์ธ์ˆ˜
  • bind()๋Š” ์ƒˆ๋กญ๊ฒŒ ๋ฐ”์ธ๋”ฉํ•œ ํ•จ์ˆ˜๋ฅผ ๋งŒ๋“ ๋‹ค. ๋ฐ”์ธ๋”ฉํ•œ ํ•จ์ˆ˜๋Š” ์›๋ณธ ํ•จ์ˆ˜ ๊ฐ์ฒด๋ฅผ ๊ฐ์‹ธ๋Š” ํ•จ์ˆ˜์ด๋‹ค. bind()๋Š” call(), apply()์™€ ๊ฐ™์ด ํ•จ์ˆ˜๊ฐ€ ๊ฐ€๋ฆฌํ‚ค๊ณ  ์žˆ๋Š” this๋ฅผ ๋ฐ”๊พธ์ง€๋งŒ ํ˜ธ์ถœ๋˜์ง€๋Š” ์•Š๋‹ค. ๋”ฐ๋ผ์„œ ๋ณ€์ˆ˜๋ฅผ ํ• ๋‹นํ•˜์—ฌ ํ˜ธ์ถœํ•˜๋Š” ํ˜•ํƒœ๋กœ ์‚ฌ์šฉ๋œ๋‹ค.
 
 

Function.prototype.bind() - JavaScript | MDN

bind() ๋ฉ”์†Œ๋“œ๊ฐ€ ํ˜ธ์ถœ๋˜๋ฉด ์ƒˆ๋กœ์šด ํ•จ์ˆ˜๋ฅผ ์ƒ์„ฑํ•ฉ๋‹ˆ๋‹ค. ๋ฐ›๊ฒŒ๋˜๋Š” ์ฒซ ์ธ์ž์˜ value๋กœ๋Š” this ํ‚ค์›Œ๋“œ๋ฅผ ์„ค์ •ํ•˜๊ณ , ์ด์–ด์ง€๋Š” ์ธ์ž๋“ค์€ ๋ฐ”์ธ๋“œ๋œ ํ•จ์ˆ˜์˜ ์ธ์ˆ˜์— ์ œ๊ณต๋ฉ๋‹ˆ๋‹ค.

developer.mozilla.org

728x90

'Javascript > Javascript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

๋ฐฐ์—ด์˜ ํ•จ์ˆ˜๋“ค  (0) 2022.07.22
[Js] ๋ฐฐ์—ด ์ƒ์„ฑ  (0) 2022.07.22
[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ์‹ฑ๊ธ€์Šค๋ ˆ๋“œ, ๋น„๋™๊ธฐ์ฒ˜๋ฆฌ, ์ฝœ๋ฐฑํ•จ์ˆ˜  (0) 2022.05.29
[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ๋งค๊ฐœ๋ณ€์ˆ˜, ์ธ์ž ์šฉ์–ด ์ฐจ์ด  (0) 2022.05.27
[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ์ต๋ช…ํ•จ์ˆ˜, ํ™”์‚ดํ‘œ ํ•จ์ˆ˜, ์ฝœ๋ฐฑํ•จ์ˆ˜  (0) 2022.05.22
    'Javascript/Javascript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • ๋ฐฐ์—ด์˜ ํ•จ์ˆ˜๋“ค
    • [Js] ๋ฐฐ์—ด ์ƒ์„ฑ
    • [์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ์‹ฑ๊ธ€์Šค๋ ˆ๋“œ, ๋น„๋™๊ธฐ์ฒ˜๋ฆฌ, ์ฝœ๋ฐฑํ•จ์ˆ˜
    • [์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ๋งค๊ฐœ๋ณ€์ˆ˜, ์ธ์ž ์šฉ์–ด ์ฐจ์ด
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”