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

[๋“œ๋ฆผ์ฝ”๋”ฉ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ๋น„๋™๊ธฐ promise

2022. 4. 13. 18:29
728x90

https://youtu.be/JB_yU6Oe2eE

์ฃผ์„์€ ์ฝœ๋ฐฑ ์ง€์˜ฅ ์˜ˆ์ œ

// class UserStorage {
//   loginUser(id, password, onSuccess, onFailure) {
//     setTimeout(() => {
//       if (
//         (id === "ํ™๊ธธ๋™" && password === "์•„๋ฒ„์ง€") ||
//         (id === "ํ™ฉ์ง„์ด" && password === "์ฒญ์‚ฐ๋ฆฌ")
//       ) {
//         onSuccess(id);
//       } else {
//         onFailure(new Error("not found"));
//       }
//     }, 2000);
//   }

//   getRoles(user, onSuccess, onFailure) {
//     setTimeout(() => {
//       if (user === "ํ™๊ธธ๋™") {
//         onSuccess({
//           name: "ํ™๊ธธ๋™",
//           role: "์•„๋ฒ„์ง€๋ฅผ ์•„๋ฒ„์ง€๋ผ ๋ถ€๋ฅด์ง€๋„ ๋ชปํ•˜๊ณ ...",
//         });
//       } else {
//         onFailure(new Error("no access!!!"));
//       }
//     }, 3000);
//   }
// }

// const userStorage = new UserStorage();
// const id = prompt("๋„ˆ์˜ ์ด๋ฆ„์€");
// const password = prompt("๋น„๋ฐ€๋ฒˆํ˜ธ๋Š”?");
// userStorage.loginUser(
//   id,
//   password,
//   (user) => {
//     userStorage.getRoles(
//       user,
//       (userWithRole) => {
//         alert(`Hello ${userWithRole.name}, ๋„ˆ์˜ ๋ช…๋Œ€์‚ฌ ${userWithRole.role}`);
//       },
//       (error) => {
//         console.log(error);
//       }
//     );
//   },
//   (error) => {
//     console.log(error);
//   }
// );

// 1. Producer
// when new Promise is created, the executor runs automatically
// ํ”„๋กœ๋ฏธ์Šค๊ฐ€ ๋งŒ๋“ค์–ด์ง€๋Š” ์ˆœ๊ฐ„ ์ˆ˜ํ–‰!
const promise = new Promise((resolve, reject) => {
  //doing some heavy work(network, read files)
  console.log("doing something...");
  setTimeout(() => {
    resolve("๋‚ด๊ฐ€๋ฐ”๋กœ๋“ค์–ด์˜จ๊ฐ’");
  }, 2000);
});

// 2. Consumers : then, catch, finally
promise
  .then((value) => {
    console.log(value);
  })
  .catch((error) => {
    console.log(error);
  })
  .finally(() => {
    console.log("finally");
  });

% node index.js
doing something...
๋‚ด๊ฐ€๋ฐ”๋กœ๋“ค์–ด์˜จ๊ฐ’

 

then์€ ํ”„๋กœ๋ฏธ์Šค๊ฐ€ ์ž˜ ์ˆ˜ํ–‰๋˜์–ด์„œ ์ตœ์ข…์ ์œผ๋กœ 

resolve๋ผ๋Š” ์ฝœ๋ฐฑํ•จ์ˆ˜๋ฅผ ํ†ตํ•ด์„œ ์ „๋‹ฌํ•œ ๊ฐ’์ด value ํŒŒ๋ผ๋ฏธํ„ฐ๋กœ ์ „๋‹ฌ๋˜์–ด์ ธ์„œ ๋“ค์–ด์˜ค๋Š” ๊ฒƒ์„ ๋ณผ ์ˆ˜๊ฐ€ ์žˆ๋‹ค.

// 2. Consumers : then, catch, finally
promise.then((value) => {
console.log(value);
});

<ํ”„๋กœ๋ฏธ์Šค ์ฒด์ด๋‹>

//3.promise chaining
const fetchNumber = new Promise((resolve, reject) => {
  setTimeout(() => resolve(1), 1000); //1
});

fetchNumber
  .then((number) => number * 2) //2
  .then((number) => number * 3) //6
  .then((number) => {
    return new Promise((resolve, reject) => {
      setTimeout(() => resolve(number - 1), 1000);
    }); //5
  })
  .then((number) => console.log(number)); //5

 

 

//4.Error Handling
const getHen = () =>
  new Promise((resolve, reject) => {
    setTimeout(() => resolve("๋‹ญ"), 4000);
  });

const getEgg = (hen) =>
  new Promise((resolve, reject) => {
    setTimeout(() => resolve(`${hen}=>egg`), 4000);
  });

const cook = (egg) =>
  new Promise((resolve, reject) => {
    setTimeout(() => resolve(`${egg}=>ํ›„๋ผ์ด`), 4000);
  });

getHen()
  .then((hen) => getEgg(hen))
  .then((egg) => cook(egg))
  .then((meal) => console.log(meal));

๋‹ญ=>egg=>ํ›„๋ผ์ด

 

//4.Error Handling
const getHen = () =>
  new Promise((resolve, reject) => {
    setTimeout(() => resolve("๋‹ญ"), 4000);
  });

const getEgg = (hen) =>
  new Promise((resolve, reject) => {
    setTimeout(() => resolve(`${hen}=>egg`), 4000);
  });

const cook = (egg) =>
  new Promise((resolve, reject) => {
    setTimeout(() => resolve(`${egg}=>ํ›„๋ผ์ด`), 4000);
  });

getHen().then(getEgg).then(cook).then(console.log);
getHen() //
  .then(getEgg)
  .then(cook)
  .then(console.log)
  .catch(console.log);

 

 

์ฝœ๋ฐฑ ์ง€์˜ฅ์„ ํ”„๋กœ๋ฏธ์Šค๋กœ ๋ณ€๊ฒฝ!

class UserStorage {
  loginUser(id, password) {
    return new Promise((resolve, reject) => {
      setTimeout(() => {
        if (
          (id === "ํ™๊ธธ๋™" && password === "์•„๋ฒ„์ง€") ||
          (id === "ํ™ฉ์ง„์ด" && password === "์ฒญ์‚ฐ๋ฆฌ")
        ) {
          resolve(id);
        } else {
          reject(new Error("not found"));
        }
      }, 2000);
    });
  }

  getRoles(user) {
    return new Promise((resolve, reject) => {
      setTimeout(() => {
        if (user === "ํ™๊ธธ๋™") {
          resolve({
            name: "ํ™๊ธธ๋™",
            role: "์•„๋ฒ„์ง€๋ฅผ ์•„๋ฒ„์ง€๋ผ ๋ถ€๋ฅด์ง€๋„ ๋ชปํ•˜๊ณ ...",
          });
        } else {
          reject(new Error("no access!!!"));
        }
      }, 3000);
    });
  }
}

const userStorage = new UserStorage();
const id = prompt("๋„ˆ์˜ ์ด๋ฆ„์€");
const password = prompt("๋น„๋ฐ€๋ฒˆํ˜ธ๋Š”?");
userStorage //
  .loginUser(id, password)
  .then(userStorage.getRoles)
  .then((user) => alert(`Hello ${user.name}, ๋„ˆ์˜ ๋ช…๋Œ€์‚ฌ ${user.role}`))
  .catch(console.log);

 

728x90

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

generate random id ์— ๋Œ€ํ•œ ๊นƒํ—ˆ๋ธŒ ๋‹ต๋ณ€  (0) 2022.04.17
์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ๋ฐ˜๋ณต๋ฌธ  (0) 2022.04.14
[๋“œ๋ฆผ์ฝ”๋”ฉ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ]๋น„๋™๊ธฐ์˜ ์‹œ์ž‘ ์ฝœ๋ฐฑ์ง€์˜ฅ  (0) 2022.04.13
[์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ์ค‘๊ธ‰] call, apply, bind  (0) 2022.03.28
[๊ธฐ์ดˆ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ] ๋“œ๋ฆผ์ฝ”๋”ฉ by ์—˜๋ฆฌ๋‹˜ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ๊ธฐ์ดˆ ๊ฐ•์˜ (ES5+) ์‹œ๋ฆฌ์ฆˆ ์ •์ฃผํ–‰ ๊ธฐ๋ก  (0) 2022.03.25
    'Javascript/Javascript' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • generate random id ์— ๋Œ€ํ•œ ๊นƒํ—ˆ๋ธŒ ๋‹ต๋ณ€
    • ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ๋ฐ˜๋ณต๋ฌธ
    • [๋“œ๋ฆผ์ฝ”๋”ฉ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ]๋น„๋™๊ธฐ์˜ ์‹œ์ž‘ ์ฝœ๋ฐฑ์ง€์˜ฅ
    • [์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ์ค‘๊ธ‰] call, apply, bind
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

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