반응형

🚀 기초 React (1강 ~ 8강)

> 강의 보러가기 

 

🙋🏻‍♂️ Node.js 란 ?

예전에는 자바스크립트 런타임이 브라우저 밖에 존재하질 않았다. 이러한 한계를 극복하고 나온 자동차의 엔진과 같은 역활.

 

🙋🏻‍♂️ Express.js란 ?

node.js를 쉽게 이용할 수 있게 해주는 자바스크립트 프레임워크.

 

📁 폴더 생성 순서

  • Documents에 접속 > 터미널(or git bash) > npm init 입력 > package.json 생성 > index.js 만들기

 

💾 명령어

  • npm express --save // --save를 적어주면 package.json에 기록되므로, 타인이 설치된 내용에 대해 쉽게 알 수 있다.

  • npm run start // server 시작. 변경 사항이 자동으로 반영되지 않기 때문에 페이지를 새로고침 해야한다.

 

📂 Express.js 만들기

> Documents

 

const express = require('express')
const app = express()
const port = 3000

app.get('/', (req, res) => {
  res.send('Hello World!')
})

app.listen(port, () => {
  console.log(`Example app listening at http://localhost:${port}`)
})
  • require() 은 뭘까? => 확인

 

 

반응형
반응형

🚀 바닐라 JS 계산기

바닐라 자바스크립트로 간단한 계산기를 만들어 보았다. 은근히 신경써주어야 할 부분들이 많았다.. 코드가 너무 지저분 해...... 리팩토링이 필요해 !


🍙 CSS & HTML

<!DOCTYPE html>
<html>
  <head>
    <title>Parcel Sandbox</title>
    <meta charset="UTF-8" />
  </head>
  <body>
    <div class="container">
        <div class="result"><input type="text" class="show" value="0"/></div>
        <button class="cancle" data-Type="ac">C</button>
        <button class="number">7</button>
        <button class="number">8</button>
        <button class="number">9</button>
        <button class="operation" data-Type="operator">+</button>
        <button class="number">4</button>
        <button class="number">5</button>
        <button class="number">6</button>
        <button class="operation" data-Type="operator">-</button>
        <button class="number">1</button>
        <button class="number">2</button>
        <button class="number">3</dbuttoniv>
        <button class="operation" data-Type="operator">*</button>
        <button class="zero number">0</button>
        <button class="operation" data-Type="equals">=</button>
        <button class="operation" data-Type="operator">/</button>
    </button>
    <script src="src/index.js"></script>
  </body>
</html>

 

 

body {
  font-family: sans-serif;
  background-color: black;
}

button {
  color: white;
  font-size: 20px;
}

input {
  background-color: black;
  color: white;
  width: 95%;
  height: 60px;
  text-align: right;
  font-size: 40px;
  border: none;
}

.container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background-color: black;
  color: white;
  padding: 10px;
}

.result {
  grid-column: 1/4;
}

.zero {
  grid-column: 1/3;
}

.number {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(48, 47, 47, 0.925);
  margin: 3px;
  height: 60px;
  border-radius: 10px;
}

.operation {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: orange;
  margin: 3px;
  height: 60px;
  border-radius: 10px;
}

.cancle {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: gray;
  margin: 3px;
  height: 60px;
  border-radius: 10px;
}

 

🍙 결과 화면

 

🍙 Javascript

// <⚠️ DONT DELETE THIS ⚠️>
import "./styles.css";
// <⚠️ /DONT DELETE THIS ⚠️>

const buttons = document.querySelectorAll("button");
const input = document.querySelector(".show");

let result = "";
let operCheck = false;
let numberCheck = true;
let equlasCheck = true;

function init() {
  buttons.forEach((button) => {
    button.addEventListener("click", () => {
      switch (button.dataset.type) {
        case "operator":
          const oper = button.innerText;
          operator(oper);
          break;
        case "ac":
          clear();
          break;
        case "equals":
          calc();
          break;
        default:
          const number = button.innerText;
          displayNumber(number);
          break;
      }
    });
  });
}

function displayNumber(number) {
  operCheck = true;
  const current = input.value;

  //계산 끝난 후 초기화
  if (equlasCheck) {
    //연산자 눌렸을 시 계산기 값만 초기화
    if (numberCheck) {
      input.value = current === "0" ? number : input.value + number;
    } else {
      input.value = number;
      numberCheck = true;
    }
    result += number;
  } else {
    equlasCheck = true;
    input.value = number;
    result = number;
    console.log(result);
  }
}

function calc() {
  // 지속적으로 계산기 값 누르는 거 확인
  if (input.value === "0") {
    clear();
  } else {
    //마지막이 연산자로 끝나는 지 확인
    if (!operCheck) {
      alert("Calculation is unavailable because of operation.");
    } else {
      // 계속 눌렸을 때 변경
      if (equlasCheck) {
        const final = eval(result);
        input.value = `RESULT : ${final}`;
        result = "";
        equlasCheck = false;
        operCheck = false;
      } else {
        clear();
      }
    }
  }
}

function operator(oper) {
  if (!operCheck) {
    alert("Operation Error.");
  } else {
    operCheck = false;
    result += oper;
    numberCheck = false;
  }
}

function clear() {
  input.value = 0;
  result = "";
  operCheck = false;
  equlasCheck = true;
}

init();
반응형
반응형

🚀 FLEX

기존의 TABLE 이나 Float를 사용하던 Layout을 간편하게 사용하기 위해 고안된 방법


📢 기본구조

<container>
  <item></item>
  <item></item>
<container>

태그와 class값은 변해도 된다. 하지만 부모, 자식 관계는 꼭 유지해야 한다 !

 

📢 관련 속성

container

  • display
  • flex-diection
  • flex-wrap
  • flex-flow
  • justify-content
  • align-items
  • align-content

item

  • order
  • flex-grow
  • flex-shrink
  • flex-basis
  • flex
  • algin-self

 

📢 Holy grail layout

출처-생활코딩

 

<!DOCTYPE html>
<html>
  <head>
    <style>
      .container {
        display: flex;
        flex-direction: column;
      }

      header {
        border-bottom: 1px solid gray;
      }

      footer {
        border-top: 1px solid gray;
      }

      .content {
        display: flex;
      }

      .content nav {
        border-right: 1px solid gray;
      }

      .content aside {
        border-left: 1px solid gray;
      }

      nav,
      aside {
        flex-basis: 200px;
        flex-shrink: 0;
      }

      main {
        flex-grow: 1;
        padding: 10px;
      }
    </style>
  </head>
  <body>
    <div class="container">
      <header>
        <h1>생활코딩</h1>
      </header>
      <section class="content">
        <nav>
          <ul>
            <li>html</li>
            <li>css</li>
            <li>javascript</li>
          </ul>
        </nav>
        <main>
          냠냠
        </main>
        <aside>
          AD
        </aside>
      </section>
      <footer>
        https://taiyakee.tistory.com
      </footer>
    </div>
  </body>
</html>

 

반응형
반응형

🚀 게임 회사 백엔드 개발자 면접 회고

올해 처음으로(농심을 까먹었네) 두번째로 개발자로 면접을 보았다. 그동안도 전공과 관련된 직무였지만, 준비하던 직무는 아니었기에 탈락했을 때 회복이 금방되었다. 하지만 이번에는 준비하던 직무 면접을 보았고 어느 질문에도 명확하게 대답하지 못 한거 같다. 한심하다.

 

같은 실수를 반복하지 않기 위해 이렇게 회고한다.


🍙  JAVA

  • OOP( Object Oriented Programming ) 설명

  • Exception, Error의 차이
  • RuntimeException 이란?
  • Statement, PreparedStatement 차이
  • Connection Pool 을 사용하는 이유는?

 

🍙  Spring Framework

  • DI( Dependency Injection ) 설명
  • 그 외 Spring의 특징
  • MVC 패턴이란?
  • MVC 패턴을 사용하면 좋은 점은?
  • 유지보수와 코드 가독성이 좋다고 그랬는데, 그에 대한 예시를 제시
  • Ouath 2.0 Token에 대한 설명
  • Ouath 2.0 Token 발생 Flow
  • Ouath 2.0 Authoriztion 이란 ?
  • JWT에 대한 설명
  • JWT란 언제, 왜 사용되는지?
  • Ouath 2.0 과 JWT에 대한 차이
  • JWT가 보안성에 좋다고 하였는데 왜 그렇게 생각하는지?

 

🍙  DataBase

  • Hint에 대한 설명
  • Plan에 대한 설명
  • Explain 결과를 보면 방법에 대한 설명
  • 테이블 정규화란?
  • SQL을 작성할 때 어떻게 작성해야 효율적인지
  • JOIN시 발생하는 Cating에 대한 이슈를 설명

 

🍙  Project

  • 개발한 어플리케이션을 원스토어에 등록한 이유는?
  • 카카오 SDK 연동하는 FLOW 설명
  • 카카오 SDK 토큰은 어떻게 사용되는지
  • 졸업 작품에 대한 설명

 

🍙 ETC

  • 공개키에 대한 설명
  • 암호 알고리즘에 대해 아는 대로 설명
  • 흥미 또는 관심있게 수강한 과목

 

반응형

+ Recent posts