어떤 정보에 이름을 붙여서 사용
ex) name = "Mike";
age = 30;
(문자는 ' '
" "
로 감싸주어야 함)
자바스크립트에서 이미 사용 하는 단어(예약어,reserved word)는 변수로써 사용 불가(ex: class)
alert()
: 경고창을 띄우는 함수
name = "Mike";
age = 30;
alert(name);
→ Mike 라고 적힌 alert창 뜸
console.log
: 로그를 찍는 함수name = "Mike";
age = 30;
console.log(age);
→ Console창에 30이라고 뜸
let
: 변수 중복방지, 수정가능함let name = "Mike";
//...
let name = "google";
→ 구문오류(syntaxerror) 발생 : 이미 선언된 변수로 표시됨
let grade = "F";
//...
grade = "A+";
→ 의도적으로 let을 생략하고 작성하면 됨
let
을 붙인다면, 이미 사용된 변수는 에러를 통해서 알 수 있음 const
: 변수 중복방지, 절대로 바뀌지 않는 상수, 수정 불가const PI = 3.14;
const SPEED_LIMIT = 50;
const BIRTH_DAY = '2020-01-01';
→ const를 변수로 사용함으로써 변하지 않는 값임을 알림
TIP ! 모든 변수를 const로 선언하고, 나중에 변경될 여지가 있는 변수들을 let으로 수정
<변수에 대한 추가 내용>
const MY_HOME = ",,,";
let_ = 1;
let$ = 3;
let let = 99; (X)
const name = "Mike"; //문자형 String
<문자형의 작성 방식 3가지>
const name1 = "Mike"; //큰 따옴표
const name1 = 'Mike'; //작은 따옴표
const name1 = `Mike`; //백틱(숫자키 1 옆의 기호)
→ 큰 따옴표와 작은 따옴표의 큰 차이는 없음
→ 백틱은 문자열 내부의 변수를 표현할 때 편리
ex)
const message1 = `My name is ${name}`;
console.log(message1)
→console창에 "My name is Mike" 라고 출력됨
→${변수} 쓰면 변수값으로 변환되어 출력됨
ex)
const message2 = `나는 ${30+1}살 입니다.`;
console.log(message2)
→ console창에 "나는 31살 입니다." 라고 출력됨
★백틱 대신 일반 따옴표로 작성할 시
const name = "Mike";
const message1 = `My name is ${name}`;
console.log(message1)
→console창에 "My name is ${name}" 라고 그대로 출력됨
ex)
문자형 + 문자형
const name = "Mike";
const a = "나는 ";
const b = " 입니다.";
console.log(a + name + b);
→ 나는 Mike 입니다.
ex)
문자형 + 숫자형 //문자형으로 변경됨
const age = 30; //number
console.log(a + age + "살" + b)
→ 나는 30살 입니다.
const age = 30; //숫자형 Number
const PI = 3.14; //소수점 표현도 가능
//사칙연산 가능
console.log(1 + 2); //더하기
console.log(1 - 2); //빼기
console.log(1 * 2); //곱하기
console.log(1 / 2); //나누기
console.log(1 % 2); //나머지
ex)
const 1/0; //어떤 숫자를 0으로 나눈다면??
console.log(x)
→ console창에 'Infinity' 출력됨
ex)
const name = "Mike";
const y = name/2; //문자를 숫자로 나눈다면??
console.log(y)
→ colsole창에 'NaN' 출력(NaN=Not a number)
const a = true; //참
const b = false; //거짓
ex)
const name = "Mike"
const age = 30;
console.log(name == 'Mike') //true 출력
console.log(age > 40) //false 출력
ex)
let age; //값이 선언만 되고 할당되지 않음
console.log(age) //undefined 출력
ex)
let user = null; //user는 존재하지 않는다는 의미
const name = "Mike";
console.log(typeof 3); //number
console.log(typeof name); //string
console.log(typeof true); //boolean
console.log(typeof "xxx"); //string
console.log(typeof undefined) //undefined
console.log(typeof null); //object(객체형을 의미)
→ null은 객체가 아님
alert()
: 알려줌const isAdult = alert("당신은 성인 입니까?")
console.log(isAdult)
prompt()
: 입력 받음const name = prompt("이름을 입력하세요.");
alert("환영합니다, " + name + "님");
혹은
alert(`환영합니다, ${name}님`);
→ 값을 입력하지 않고, '취소'버튼 누를 시 null
값 반영
→ Prompt는 default 값도 입력 가능
const name = prompt("예약일을 입력해주세요.", "2020-10-");
→ prompt는 두개의 인수를 받을 수 있으며,
첫번째 값은 메세지, 두번째 값은 입력받을 디폴트 값
→ 디폴트 값을 입력함으로써 무언가를 안내하거나, 힌트를 줄 때 유용
confirm()
: 확인 받음const isAdult = confirm("당신은 성인 입니까?")
console.log(isAdult)
→ <결제 하시겠습니까?> <정말 삭제 하시겠습니까?> 등과 같은 사용자의 액션을 확인해주고자 할 때 사용
이렇게 기본적으로 제공되는 창
들의 단점
그럼에도 불구하고, 기본 메서드는 빠르고 간단하게 적용가능한 장점으로 많이 사용됨