오늘 한일
변수와 자료형
조건문
문자열
학습언어 - Javascipt
개념정리
const pow1 = x * x;
const pow2 = x ** 2;
const pow3 = Math.pow(x, 2);
==는 Equal Operator이고, ===는 Strict Equal Operator이다.
==는 a == b 라고 할때, a와 b의 값이 같은지를 비교해서, 같으면 true, 다르면 false라고 한다.(값만 같으면 true이다.)
===는 Strict, 즉 엄격한 Equal Operator로써, "엄격하게" 같음을 비교할 때 사용하는 연산자이다.
===는 a === b 라고 할때, 값과 값의 종류(Data Type)가 모두 같은지를 비교해서, 같으면 true, 다르면 false라고 한다.
'==' 연산자를 이용하여 서로 다른 유형의 두 변수의 [값] 비교
'==='는 엄격한 비교를 하는 것으로 알려져 있다 ([값 & 자료형] -> true).
예시)
var a = 1;
var b = "1";
console.log(a == b); // true
console.log(a === b); // false
console.log(null == undefined); // true
console.log(null === undefined); // false
console.log(typeof null); // expected output: "object"
console.log(typeof undefined); // expected output: "undefined"
console.log(true == 1); // true
console.log(true === 1); // false
console.log(typeof 1); // expected output: "number"
console.log(typeof true); // expected output: "boolean"
console.log(NaN == NaN); // false
console.log(NaN === NaN); // false
변수를 비교하거나 어떤 비교를 위해 항상 '===' 연산자를 사용 할 것을 권장한다.
*추가) 배열이나 객체의 경우
var a = [1,2,3];
var b = [1,2,3];
console.log(a == b); // false
console.log(a === b); // false
배열을 할당할때, 각 변수는 각 메모리의 주소를 참조한다.
두 변수 a, b의 값과 데이터 타입이 같지만, 이와 상관없이
참조하는 메모리의 주소가 다르기 때문에 두 a, b는 같지 않다.
var a = [1,2,3];
var b = [1,2,3];
var c = b;
console.log(b === c); // true
console.log(b == c); // ture
새로운 변수 c에 변수 b를 할당해주면, 변수 c도 b가 참조하는 같은 메모리의 주소를 참조하게 되어,
두 변수 c, b는 같다. 이때, c, b의 값과 데이터 타입이 같기 때문에, ==와 ===의 결과값이 동일하다.
객체도 배열과 같은 경우이다.
var x = {};
var y = {};
var z = y;
console.log(x == y) // false
console.log(x === y) // false
console.log(y === z) // true
console.log(y == z) // true
다음은 if문에서 false로 변환되므로, if 구문이 실행되지 않는다.
if(false)
if(null)
if(undefined)
if(0)
if(NaN)
if('')