Jquery ๋ฐฐ์—ด ๋ณต์‚ฌ - Jquery baeyeol bogsa

Bbaktaeho

Jquery ๋ฐฐ์—ด ๋ณต์‚ฌ - Jquery baeyeol bogsa

๐Ÿ“š ๋ณต์‚ฌ

  • ๋จผ์ € ๋ณต์‚ฌ๋ž€, ์›๋ณธ๊ณผ ๋ชจ๋‘ ๊ฐ™์€ ๋‚ด์šฉ์œผ๋กœ ์‚ฌ๋ณธ์„ ๋งŒ๋“œ๋Š” ์ž‘์—…
  • ์›๋ณธ์€ ๋”ฐ๋กœ ์กด์žฌํ•˜๊ณ  ์‚ฌ๋ณธ๋„ ๋”ฐ๋กœ ์กด์žฌํ•˜๊ฒŒ, ์ฆ‰ ์›๋ณธ๊ณผ ์‚ฌ๋ณธ์€ ๋‚ด์šฉ์€ ๊ฐ™์ง€๋งŒ ์„œ๋กœ ๋‹ค๋ฅด๊ฒŒ ์กด์žฌํ•˜๊ณ  ์žˆ๋‹ค๋Š” ๋œป์ž„

๐Ÿ“— ์–•์€ ๋ณต์‚ฌ

์‚ฌ๋ณธ์„ ๋งŒ๋“ค์–ด๋‚ด์ง€ ์•Š๊ณ  ์›๋ณธ์„ ์ฐธ์กฐํ•˜๋„๋ก ๋ณต์‚ฌํ•œ ์ฒ™์„ ํ•˜๋Š” ๊ฒƒ

  • ๊ธฐ๋ณธํ˜•์—์„œ ์–•์€ ๋ณต์‚ฌ
    ๊ธฐ๋ณธํ˜• ํƒ€์ž…์—์„œ ๋ณต์‚ฌํ•œ ๋ฐ์ดํ„ฐ๋ฅผ ๋ณ€๊ฒฝํ•  ๋•Œ ์›๋ณธ๋„ ๊ฐ™์ด ๋ณ€๊ฒฝ๋˜๋Š” ์ผ์€ ๋ฐœ์ƒํ•˜์ง€ ์•Š๋Š”๋‹ค.

    var v1 = "test";
    var v2 = v1; // (1)
    
    console.log(v1);
    console.log(v2);
    
    v2 = "hi taeho"; // (2)
    
    console.log(v1);
    console.log(v2);
    test
    test
    test
    hi taeho

    ์ฃผ์„(1) ์ฝ”๋“œ์—์„œ ๋ฉ”๋ชจ๋ฆฌ ๋ณ€ํ™”

    Jquery ๋ฐฐ์—ด ๋ณต์‚ฌ - Jquery baeyeol bogsa
    ๋‘ ๋ณ€์ˆ˜๋Š” ์„œ๋กœ ๊ฐ™์€ ์ฃผ์†Ÿ๊ฐ’์„ ์ฐธ์กฐํ•˜๊ณ  ์žˆ์Œ

    ์ฃผ์„(2) ์ฝ”๋“œ์—์„œ ๋ฉ”๋ชจ๋ฆฌ ๋ณ€ํ™”

    Jquery ๋ฐฐ์—ด ๋ณต์‚ฌ - Jquery baeyeol bogsa
    ์›๋ณธ์˜ ์ฃผ์†Œ๋ฅผ ์ฐธ์กฐํ•˜๊ณ  ์žˆ์—ˆ์ง€๋งŒ ์ƒˆ๋กœ์šด ๋ฐ์ดํ„ฐ๋กœ ๋ณ€๊ฒฝํ•  ๋•Œ ๋ฐ์ดํ„ฐ ์˜์—ญ์—์„œ ์ƒˆ๋กœ์šด ๋ฐ์ดํ„ฐ๋ฅผ ํ• ๋‹นํ•˜๊ณ  ๊ทธ ์ฃผ์†Ÿ๊ฐ’์„ ๋‹ค์‹œ ์ฐธ์กฐํ•จ
  • ์ฐธ์กฐํ˜•์—์„œ ์–•์€ ๋ณต์‚ฌ

    var arr1 = [1, 2, 3, 4];
    var arr2 = arr1; // (1)
    
    console.log(arr1);
    console.log(arr2);
    
    arr2[0] = 0; // (2)
    
    console.log(arr1);
    console.log(arr2);
    [ 1, 2, 3, 4 ]
    [ 1, 2, 3, 4 ]
    [ 0, 2, 3, 4 ]
    [ 0, 2, 3, 4 ]

    ์ฃผ์„(1) ์ฝ”๋“œ์—์„œ ๋ฉ”๋ชจ๋ฆฌ ๋ณ€ํ™”

    Jquery ๋ฐฐ์—ด ๋ณต์‚ฌ - Jquery baeyeol bogsa
    ๋‘ ๋ณ€์ˆ˜๋Š” ์„œ๋กœ ๊ฐ™์€ ์ฃผ์†Ÿ๊ฐ’์„ ์ฐธ์กฐํ•˜๊ณ  ์žˆ์Œ

    ์ฃผ์„(2) ์ฝ”๋“œ์—์„œ ๋ฉ”๋ชจ๋ฆฌ ๋ณ€ํ™”

    Jquery ๋ฐฐ์—ด ๋ณต์‚ฌ - Jquery baeyeol bogsa
    arr2 ๊ฐ€ arr1 ๊ณผ ๊ฐ™์€ ๋ฐฐ์—ด์„ ์ฐธ์กฐํ•˜๊ณ  ์žˆ๊ธฐ ๋•Œ๋ฌธ์— ์‚ฌ๋ณธ์ธ arr2 ์—์„œ ๋ฐฐ์—ด์˜ ์š”์†Œ๋ฅผ ์ˆ˜์ •ํ–ˆ์„ ๋•Œ ์›๋ณธ์—๋„ ์ˆ˜์ •์ด ์ผ์–ด๋‚จ. ์ฆ‰, ์›๋ณธ์„ ๊ฐ€๋ฆฌํ‚ค๋Š” ๋˜ ๋‹ค๋ฅธ ์‹๋ณ„์ž๊ฐ€ ์ƒ๊ฒจ๋‚œ ๊ฒƒ์ž„(์–•์€ ๋ณต์‚ฌ)

๐Ÿ“’ ๊นŠ์€ ๋ณต์‚ฌ

์™„๋ฒฝํ•˜๊ฒŒ ์›๋ณธ๊ณผ ์‚ฌ๋ณธ์„ ๋‚˜๋ˆ  ๋ณต์‚ฌํ•˜๋Š” ๋ฐฉ๋ฒ•

  • ๋ฐฐ์—ด์˜ ๋ณต์‚ฌ (๊นŠ์€ ๋ณต์‚ฌ๊ฐ™์€ ์–•์€ ๋ณต์‚ฌ)
    Array.prototype.slice() ๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด ์ƒˆ๋กœ์šด ๋ฐฐ์—ด์„ ๋ฐ˜ํ™˜ํ•ด์ค€๋‹ค. (์ฐธ์กฐํ˜• ์š”์†Œ๊ฐ€ ์žˆ๋‹ค๋ฉด ์–•์€ ๋ณต์‚ฌ)

    var arr1 = [1, 2, 3, 4];
    var arr2 = arr1.slice();
    
    console.log("arr1: ", arr1);
    console.log("arr2: ", arr2);
    
    arr2[0] = 0;
    
    console.log("arr1: ", arr1);
    console.log("arr2: ", arr2);
    
    console.log(arr1 === arr2);
    arr1:  [ 1, 2, 3, 4 ]
    arr2:  [ 1, 2, 3, 4 ]
    arr1:  [ 1, 2, 3, 4 ]
    arr2:  [ 0, 2, 3, 4 ]
    false
  • ๊ฐ์ฒด์˜ ๊นŠ์€ ๋ณต์‚ฌ
    ๊ฐ์ฒด์— ๋”ฐ๋ฅธ ์‚ฌ์šฉ์ž ์ •์˜ ํ•จ์ˆ˜๋ฅผ ๋งŒ๋“ค์–ด ๋ณต์‚ฌํ•  ์ˆ˜ ์žˆ๋‹ค.

    function deepCopy(o) {
      var result = {};
      if (typeof o === "object" && o !== null)
        for (i in o) result[i] = deepCopy(o[i]);
      else result = o;
      return result;
    }
    var obj1 = {
      a: 1,
      b: [1, 2, 3]
    };
    
    var obj2 = deepCopy(obj1);
    
    console.log(obj1 === obj2);
    console.log(obj1);
    console.log(obj2);
    false
    { a: 1, b: [ 1, 2, 3 ] }
    { a: 1, b: { '0': 1, '1': 2, '2': 3 } }
  • JSON.parse, JSON.stringify ๋กœ ๋ณต์‚ฌ
    ๊นŠ์€ ๋ณต์‚ฌ๋Š” ๊ฐ€๋Šฅํ•˜์ง€๋งŒ gettser/setter ๋“ฑ JSON ์œผ๋กœ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์—†๋Š” ํ”„๋กœํผํ‹ฐ๋Š” ๋ฌด์‹œํ•œ๋‹ค. ๋ฐฐ์—ด๋„ ๊นŠ์€ ๋ณต์‚ฌ๊ฐ€ ๊ฐ€๋Šฅํ•˜์ง€๋งŒ ๋ฐฐ์—ด ๊ด€๋ จ ํ•จ์ˆ˜๋Š” ์‚ฌ์šฉ ๋ถˆ๊ฐ€๋Šฅํ•˜๋‹ค.

    var obj1 = {
      a: "hello",
      b: [1, 2, 3],
      c: { cc: "left" }
    };
    
    var obj2 = JSON.parse(JSON.stringify(obj1));
    
    console.log(obj1);
    console.log(obj2);
    console.log(obj1 === obj2);
    
    obj2.c.cc = "right";
    
    console.log(obj1);
    console.log(obj2);
    { a: 'hello', b: [ 1, 2, 3 ], c: { cc: 'left' } }
    { a: 'hello', b: [ 1, 2, 3 ], c: { cc: 'left' } }
    false
    { a: 'hello', b: [ 1, 2, 3 ], c: { cc: 'left' } }
    { a: 'hello', b: [ 1, 2, 3 ], c: { cc: 'right' } }

'ํ”„๋กœ๊ทธ๋ž˜๋ฐ (Programming) > ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ (JavaScript)' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[Javascript/Array] slice, splice (๋ฐฐ์—ด ์ž๋ฅด๊ธฐ, ๋ฐฐ์—ด ๋ณต์‚ฌ, ์–•์€ ๋ณต์‚ฌ)  (0)2020.05.23
[Javascript] undefined, empty, null ( ๋น„์–ด์žˆ๋Š” ๋ณ€์ˆ˜, ๋ฆฌํ„ด์—†๋Š” ํ•จ์ˆ˜, ๋ฐฐ์—ด์˜ ๋นˆ ๊ณต๊ฐ„)  (2)2020.03.30
[Javascript] ๋ฐ์ดํ„ฐ ํƒ€์ž…๊ณผ ํ• ๋‹น (typeof, var, memory, ๊ธฐ๋ณธํ˜•, ์ฐธ์กฐํ˜•, ๋ถˆ๋ณ€์„ฑ, ๊ฐ€๋ณ€์„ฑ)  (0)2020.03.30
[Javascript/Array] reduce, reduceRight (์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ, ๋ฐฐ์—ด ๋ฐ˜๋ณต, ๋ฐฐ์—ด์˜ ํ•ฉ, ๋ˆ„์‚ฐ๊ธฐ, accumulator)  (2)2020.03.29
[Javascript/Function] function, inner function, arrow function(์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ, ํ•จ์ˆ˜, ๋‚ด๋ถ€ ํ•จ์ˆ˜, ํ•จ์ˆ˜ ์„ ์–ธ์‹, =>)  (0)2020.03.28