data:image/s3,"s3://crabby-images/7c204/7c20439d4a2c3f0f6bef35482c2784d6a131a8ab" alt=""
javascript
자바스크립트란, 웹브라우저에서 많이 사용하는 인터프리터 방식의 객체지향 프로그래밍 언어이다.
자바스크립트는 ECMA스크립트 표준을 따르는 대표적인 웹 기술이다.
인터프리터방식
- src => object . 코딩하는 그대로 오브젝트가 된다.
컴파일방식 (인터프리터의 반대)
- .java=> class (컴파일)
- src => object (컴파일 후 실행)
여기서 object는 실제 실행파일이고, 인터프리터방식은 코딩하는 그대로 나온다고 보면 된다.
스크립트언어 : 매우빠르게 배우고 작성하기 위해 고안됨. 짧은 소스코드 파일이나 REPL(Read Eval Print Loop)로 상호작용
클라이언트 사이드 스크립트 (사용자 컴퓨터에서 처리)
- Javascript, VBscript, Jscript
서버사이드 스크립트 (정보를 제공하는 서버쪽 컴퓨터에서 처리되는 스크립트)
- ASP, PHP,JSP, 파이썬, Node.js 등
기본 작성법
작성법에는 세가지가 있다.
- html태그의 inline 이벤트 속성에 작성
- 내부 script태그 - head태그안, body종료 태그 전에 작성
- 외부 script태그 - 현재 페이지에서 외부에 작성한 태그를 load
- html태그의 inline이벤트 속성에서 작성하기
<body>
<h1>Javascript</h1>
<ol>
<li onclick="alert('안녕');">html태그의 inline 이벤트속성에 작성</li>
</ol>
다음과 같이 작성하면 되고, 크롬에서 F12를 눌러 Console에서 브라우저 개발자 도구를 확인할 수 있다.
data:image/s3,"s3://crabby-images/e0bd2/e0bd246def0419de63ab44b0b9ed1e5c0e1dfff5" alt=""
클릭시 알림창으로 안녕이 출력
되는것을 확인할 수 있다.
2. 내부 script태그 - head태그안, body종료 태그 전에 작성
3. 외부 script태그 - 현재 페이지에서 외부에 작성한 태그를 load
head부분
<script src="js/main.js"></script>
<script>
abc(); // main.js 선언된 함수 호출!
// 한줄 주석
/*
여러줄 주석
*/
console.log('123'); // 브라우져가 문서를 해석하면서 바로 실행!
// 함수선언
function foo(){
console.log("foooooooooooooooooooooooooo");
}
foo(); // 함수 호출
body부분
<script>
console.log(456);
foo();
function bar(){
console.log("baaaaaaaaaaaaaaaaaaaaaaaaaaaar");
}
main.js파일
// 스크립트 영역
function abc (){
console.log("abccccccccccccccccccccccccc");
}
console.log("main.js 실행.....................");
java와 마찬가지로 한줄주석은 //, 여러줄 주석은 /* */를 이용한다.
data:image/s3,"s3://crabby-images/e35af/e35af534c187acbaefe79e608c635aea459e8198" alt=""
다음과 같이 실행된다.
아래 body에 선언된 bar를 head에서 선언하면 어떻게 될까?
data:image/s3,"s3://crabby-images/eac11/eac11b97c2022b6307f691cea7c612fb558e7791" alt=""
다음과 같이 오류가 발생한다.
javascript는 오류가 발생시, 하위 코드가 전부 실행되지 않으므로 주의해야한다!
javascript는 위에서 아래로 코드를 실행하기 때문에 함수 선언 순서도 주의해야한다!
자료형
Dynamic Typing - javascript는 유동적인 언어로, 대입된 값에 따라 변수의 자료형이 결정된다.
변수 선언시 let 키워드를 사용
상수 선언시 const 키워드를 사용
<button onclick="test1();">Dynamic Typing</button>
function test1(){
let k; // 변수 선언
k = 123; // 값대입
console.log(typeof k, k); // number 123
k = "안녕";
console.log(typeof k, k); // string 안녕
}
data:image/s3,"s3://crabby-images/a1055/a10558c9966b3d45f32f07f9141665f02a6761d5" alt=""
다음과 같이 변수를 선언했을 때, k값에 따라 변수의 종류가 다르게 나오는 것을 확인할 수 있다.
<button onclick="test2();">자료형</button>
function test2(){
// string
// const s; // 'const' declarations must be initialized.
// s = 'heyhey';
const s = "Helloworld"; // 홑따옴표/쌍따옴표 가능 /변경되지않는 자료형
// s = "Byebyeworld"; // Uncaught TypeError: Assignment to constant variable.
console.log(typeof s, s);
// number
// 정수/실수 구분하지 않는다.
const a = 100.456;
console.log(typeof a, a);
console.log(10 / 3); // 3.3333333333333335
// boolean
// true, false
const bool = !false;
console.log(typeof bool, bool);
// object
const today = new Date(); // 생성자함수 호출 객체 생성
console.log(typeof today, today);
const arr = [1, 2, 3]; // 배열 -> 객체
console.log(typeof arr, arr);
console.log(arr[0], arr[1], arr[2]);
// 요소(속성명:속성값) - 리터럴로 객체생성
const obj = {
name : '홍길동',
n : 123.456,
married : false,
favoriteNums : [9, 12, 23],
friend : {
name : '고길동'
}
};
console.log(typeof obj, obj); // object {name: '홍길동', n: 123.456, married: false, favoriteNums: Array(3)}
console.log(obj.name);
console.log(obj.n);
console.log(obj.married);
console.log(obj.favoriteNums);
console.log(obj.friend);
// function
function foo(){
console.log('foooooooooooo');
}
console.log(typeof foo, foo);
foo();
// undefined
let k;
console.log(typeof k, k); // undefined undefined
let m = '안녕하세요';
m = undefined;
console.log(typeof m, m); // undefined undefined
}
data:image/s3,"s3://crabby-images/4ccad/4ccad3a4fe3ec121ce93828e4e35a67534baf921" alt=""
자료형종류
- string
- number
- boolean
- object
- function
- undefined
가 있다.
string
- const 변수명='변수내용' 또는 const 변수명 = "변수내용"
홑따옴표 ' ' 는 변경 가능한 자료형이고, 쌍따옴표 " "는 변경 불가능한 자료형이다.
number
- const 변수명 = 숫자
정수와 실수를 구분하지 않는다. 전부 number형으로 나온다.
boolean
- const 변수명 = true / false (! 사용가능)
object
- const 변수명 = new ___();
생성자 함수를 호출하는 객체 생성이 가능하다.
예시에서는 new Date();를 써서 현재 시각을 호출했다.
- const 변수명 = [ _, _, _ ] ;
배열을 객체로도 만들 수 있다.
- const 변수명 = { 속성명 : 속성값, 속성명: 속성값 , .... }
요소를 리터럴로 객체를 생성할 수 있다.
object안의 object가 가능하다.
function
- function 함수이름(){ 호출내용; }
함수를 만들어 호출할 수 있다.
undefined
- let 변수명; 또는 let 변수명 = 값; 변수명 = undefined; 로 설정.
타입이 undefined로 나오고 값도 undefined로 나온다.
제어문
if / switch / for / while에 대해 배워보자.
if문
<button onclick="test1();">if</button>
function test1(){
const n = Math.floor(Math.random() * 10 + 1); // 1 ~ 10 사이의 임의의 정수
console.log(n);
if(n % 2 == 0){
console.log("짝수");
}
else {
console.log("홀수");
}
}
- if
- if else
- if else if
이렇게 세가지가 존재한다.
data:image/s3,"s3://crabby-images/e4576/e45762469d8c2c84cf0e542b372e877c5bd5838e" alt=""
랜덤으로 등장하는 것을 확인할 수 있다.
switch문
<button onclick="test2();">switch</button>
function test2(){
const n = prompt("1 ~ 3사이의 정수를 입력하세요"); // string을 반환
switch(n){
case "1" : console.log('1을 입력하셨습니다.'); break;
case "2" : console.log('2을 입력하셨습니다.'); break;
case "3" : console.log('3을 입력하셨습니다.'); break;
default : console.log('잘못 입력하셨습니다.');
}
data:image/s3,"s3://crabby-images/3e786/3e78629a61304a44c2a8d1f42779d9c3ff99b107" alt=""
data:image/s3,"s3://crabby-images/ea4cd/ea4cd5c4939429adec0c2c17958623e3e5a42ea9" alt=""
1, 2, 3, 7을 창에 입력해보았더니 다음과 같이 나왔다.
for문
<button onclick="test3();">for</button>
function test3(){
// for(let i = 0; i < 10; i++){
// console.log(i);
// }
// js에는 for..each문은 존재하지않는다.
const arr = ['a', 'b', 'c'];
// for..in - Enumerable속성이 true인 속성을 순회
// 배열 사용시 index를 참조
for(let i in arr){
console.log(i, arr[i]); // index
}
// for..of - 해당객체가 iterator속성을 가지고 있는 경우 사용가능
// 배열 사용시 요소를 참조
for(let ch of arr){
console.log(ch);
}
}
for each문 존재 x
for (let A in B ) { } : B에 대한 Enumerable 속성이 true인 속성을 A로 순회
for (let A of B ) { } : B객체가 iterator속성을 가지고 있는 경우 사용이 가능하다.
data:image/s3,"s3://crabby-images/1cb7b/1cb7bad48ef0f54932f60bcc4d3bbd6b1c8d4b48" alt=""
실행시, let in은 배열 번호와 요소가 같이나오고 let of 는 요소만 나온다.
while문
<button onclick="test4();">while</button>
function test4(){
let i = 1;
while(i <= 10){
console.log(i++); // 후위증감연산 - 인접연산처리후 증감
}
let yn;
do {
yn = prompt("계속 하시겠습니까? (y/n)", 'y');
} while(yn == 'y');
}
data:image/s3,"s3://crabby-images/ffa8f/ffa8f3803b6bfe374d33270a444cf1417684ed2e" alt=""
data:image/s3,"s3://crabby-images/10384/103840f969af1ad2dbec7ed5a34828fd08822da3" alt=""
y입력시 while문이 계속 실행된다. (한번만 출력)
n입력시 while문 종료.
실습문제 구구단
/**
* @실습문제 - 구구단
* - 사용자 입력한 단수(2 ~ 9)의 구구단을 출력
* - 2 ~ 9사이의 숫자가 아닌 경우는 출력하지 않는다.
* - gugudan함수를 호출해서 출력할것
*/
function test5(){
// number타입으로 명시적 형변환 "2" -> 2
const dan = Number(prompt("구구단수(2 ~ 9)를 입력하세요", 2));
if(dan >= 2 && dan <= 9)
gugudan(dan);
}
/**
* 매개변수 dan의 타입은 호출시 매개인자에 따라 결정된다. (Dynamic Typing)
*/
function gugudan(dan){
console.log(typeof dan, dan); // string 2
for(let i = 1; i < 10; i++)
console.log(dan, "*", i, "=", dan * i);
}
data:image/s3,"s3://crabby-images/5ad5a/5ad5a3769243f404192565c4937bced2b29d35f4" alt=""
data:image/s3,"s3://crabby-images/61304/613046f3ab9159c92264cafba6da0d43e2a8b239" alt=""
DOM접근
DOM : Document Object Model
- document객체 하위에 html문서의 태그가 가진 계층구조 그대로 javascript객체로 변환해 관리
- 각각의 tag는 객체 (속성)로써 관리된다.
<div>
<ul>
<li class="group1" id="hw1" title="Helloworld1">Helloworld1</li>
<li class="group1" id="hw2">Helloworld2</li>
<li class="group2" id="hw3" title="Helloworld3">Helloworld3</li>
<li class="group2" id="hw4">Helloworld4</li>
<li class="group1 group2" id="hw5">Helloworld5</li>
</ul>
</div>
<div>
<!-- (input:checkbox[name=fruit]#fruit$+label[for=fruit$])*3 -->
<input type="checkbox" name="fruit" id="fruit1" value="사과"><label for="fruit1">사과</label>
<input type="checkbox" name="fruit" id="fruit2" value="바나나"><label for="fruit2">바나나</label>
<input type="checkbox" name="fruit" id="fruit3" value="아보카도"><label for="fruit3">아보카도</label>
<input type="checkbox" id="fruitCheckAll" onchange="test5();"><label for="fruitCheckAll">모두 선택/해제</label>
<br>
<input type="text" id="username" name="username" placeholder="username">
<br>
<input type="range" name="point" id="point" min="0" max="100" value="0" oninput="test7();">
<span id="pointView">0</span>점
</div>
<button onclick="test1()">getElementById</button>
<button onclick="test2()">getElementsByTagName</button>
<button onclick="test3()">getElementsByClassName</button>
<button onclick="test4()">getElementsByName</button>
<button onclick="test6()">@실습문제 - #username 값출력</button>
<br>
<button onclick="test8();">querySelector</button>
<button onclick="test9();">querySelectorAll</button>
data:image/s3,"s3://crabby-images/34a96/34a96f20e990005891b2aaddffb8870d7ebdc548" alt=""
/**
* getElementById
*/
function test1(){
console.dir(document); // 객체를 계층형으로 열람
const hw3 = document.getElementById("hw3");
console.dir(hw3);
console.log(hw3.style.color); // getter ""
hw3.style.color = 'hotpink'; // setter
console.log(hw3.style.color); // getter hotpink
const noElem = document.getElementById("alkfjasldfj");
console.log(typeof noElem, noElem); // object null
}
data:image/s3,"s3://crabby-images/9adb4/9adb41ed15d4da1416dcee32c75d1cec5fedcf6f" alt=""
data:image/s3,"s3://crabby-images/bb2fa/bb2fafc4da71d5330254b259b44dbaae8a74fba6" alt=""
getElementId 버튼 클릭시 hw3에 대한 객체에 접근한 값이 나오고,
id=h3만 핫핑크 색으로 바뀌었다.
console.dir(document)를 이용해서 객체를 열람할 수 있다.
/**
* getElementsByTagName
*/
function test2(){
const list = document.getElementsByTagName("li");
// console.log(list);
for(let i = 0; i < list.length; i++){
// console.log(list[i]);
list[i].style.background = 'springgreen';
list[i].style.color = '#fff'; // 컬러명, rgb함수, 16진수 모두 작성가능
}
}
data:image/s3,"s3://crabby-images/70b67/70b6785a8493f822a550753e58218366c20f9dba" alt=""
getElementByTagName 클릭시 li를 가진 객체의 배경색이 springgreen으로, 글씨는 흰색으로 바뀌었다.
/**
* getElementsByClassName
*/
function test3(){
const group1 = document.getElementsByClassName("group1");
console.log(group1);
for(let i = 0; i < group1.length; i++){
const li = group1[i];
const content = li.innerHTML;
li.innerHTML = content.replace('Helloworld','안녕세계');
}
}
data:image/s3,"s3://crabby-images/2a315/2a3152c1487b00101a901b05ca445f34350172db" alt=""
data:image/s3,"s3://crabby-images/d5d7f/d5d7f5c2dc22120d19706b7fd927445f18419582" alt=""
getElementByClassName 클릭시 HelloWorld중 group1만 안녕세계로 바뀌었다.
data:image/s3,"s3://crabby-images/ab4cf/ab4cf422df301b0e0b14ea4666cbf7e231d5f8bf" alt=""
data:image/s3,"s3://crabby-images/400b6/400b60d2c1c21e8e211dce1b40de6476374f6d6d" alt=""
이때, getElementByTagName을 클릭한 상태에서 getElementByClassName을 클릭하면, 위에 적용된 것도 그대로 적용된다. 콘솔창이 초기화되지 않기 때문이다.
/**
* getElementsByName
*/
function test4(){
const fruits = document.getElementsByName("fruit");
console.log(fruits);
// 체크된 요소의 값 출력하기
const arr = [];
for(let i = 0; i < fruits.length; i++){
const chk = fruits[i];
console.dir(chk);
if(chk.checked){
arr.push(chk.value); // 배열의 마지막 요소로 추가하기
}
}
console.log(arr);
alert(arr + "을 선택하셨습니다."); // 바나나,아보카도을 선택하셨습니다.
}
data:image/s3,"s3://crabby-images/0bd53/0bd5341f7a124e38ff65f9532e67af617cffd2aa" alt=""
data:image/s3,"s3://crabby-images/38310/38310452c55a2c447ea912f06f66c38d9c372455" alt=""
아보카도를 선택 시, 다음과 같은 알람창이 뜨고, 콘솔창에는 위와 같이 나오게 된다.
/**
* 전체선택/해제
*/
function test5(){
const fruitCheckAll = document.getElementById("fruitCheckAll");
// console.log(fruitCheckAll.checked);
const fruits = document.getElementsByName("fruit");
for(let i = 0; i < fruits.length; i++)
fruits[i].checked = fruitCheckAll.checked;
}
전체선택을 하는 함수를 만들었다. onchange 요소를 이용해서 불러주면 된다.
/**
* getElementById
* getElementsByName
*/
function test6(){
// const username = document.getElementById("username");
const username = document.getElementsByName("username")[0];
console.log(username);
alert(username.value);
username.value = ''; // 초기화
}
data:image/s3,"s3://crabby-images/582db/582db710eec7af3f395ee8a8d518cd94b0bbc015" alt=""
data:image/s3,"s3://crabby-images/72c8a/72c8aa616b3bf318fa35009d33a30e196cb3216e" alt=""
data:image/s3,"s3://crabby-images/d5e07/d5e0741eba86742177ca351c296b65afd94cdd54" alt=""
춘딩을 입력하고 @실습문제-# username값출력을 누르면 다음과 같이 뜬다.
/**
* input:range 값 시각화하기
*
* document.getElementById에 한해서 id와 동일한 이름의 변수를 선언없이 해당객체에 접근할 수 있다.
*/
function test7(){
// const point = document.getElementById("point");
// console.log(point.value);
// const pointView = document.getElementById("pointView");
pointView.innerHTML = point.value;
}
data:image/s3,"s3://crabby-images/b8ef9/b8ef94416cf98d52dd6e37711aba1393d70d5e59" alt=""
data:image/s3,"s3://crabby-images/19102/19102e64214af4033f4aa99501c9409fe9e7d90a" alt=""
포인트를 시각화하는 함수를 만들었다. 스크롤시 점수가 같이 뜬다.
/**
* querySelector
* - css선택자를 사용해서 하나의 요소만 반환
*/
function test8(){
// const username = document.querySelector("#username");
// console.log(username);
// const group1 = document.querySelector(".group1");
// console.log(group1);
const li = document.querySelector("ul li");
console.log(li);
}
data:image/s3,"s3://crabby-images/52a44/52a449c349471a1ef47c576432e4f6f7097fc08d" alt=""
querySelector를 선택시, css의 선택자를 이용하여 ul li에 해당하는 값을 불러냈다.
/**
* querySelectorAll
* - css선택자와 매칭되는 요소를 모두 배열에 담아 반환
*/
function test9(){
const group1 = document.querySelectorAll(".group1");
console.log(group1);
const list = document.querySelectorAll("ul li");
console.log(list);
}
data:image/s3,"s3://crabby-images/aca8f/aca8f2ec2c263c4702988d87b6e226923c1be4e0" alt=""
querySelectorAll 을 통해서 .group1의 요소와, ul li요소를 전부 불러냈다.