JavaScript 1
DevInCafe
목차
- 기본 문법
- 조건문
- 반복문
- 함수
- 객체
- 생성자 함수, 프토토타입, new
- 내장 객체
- jQuery
정규 표현식
1. 기본 문법
alert('Hello World')
Array.length
input
prompt('Message', 'Defstr')
Math.PI
Math.abs(-273)
함수 / 속성 / 변수 / 메서드
1. 기본 문법
alert('Hello World')
Array.length
input
prompt('Message', 'Defstr')
Math.PI
Math.abs(-273)
함수 / 속성 / 변수 / 메서드
함수
속성
변수
함수
속성
메서드
1. 기본 문법
생성자 함수 이름은 대문자
변수, 인스턴스, 함수, 메서드 이름은 소문자
여러 단어로 이루어진 식별자는 각 단어의 첫글자를 대문자로
1. 기본 문법
비교 연산자
'가방' > '하마'
1. 기본 문법
비교 연산자
'가방' > '하마'
false
1. 기본 문법
비교 연산자
alert( 30 > 20 > 10 )
1. 기본 문법
비교 연산자
alert( 30 > 20 > 10 )
alert( true > 10)
alert( 1 > 10 )
alert( false)
1. 기본 문법
비교 연산자
alert( 30 > 20 && 20 > 10)
1. 기본 문법
비교 연산자
alert( 30 > 20 && 20 > 10)
alert( true && true)
alert( true)
1. 기본 문법
undefined
선언은 됐지만 할당되지 않은 변수
1. 기본 문법
자료형 검사
typeof
alert( typeof ('String') )
alert( typeof (273) )
1. 기본 문법
자료형 검사
typeof
alert( typeof (true) )
alert( typeof (function() { }) )
alert( typeof {})
alert( typeof (blacky) )
1. 기본 문법
숫자와 문자열 자료형 변환
alert( '52 + 273')
alert(52 + 273)
alert('52' + 273)
alert(52+ '273')
alert('52' + '273')
1. 기본 문법
숫자와 문자열 자료형 변환
alert( '52 + 273')
alert(52 + 273)
alert('52' + 273)
alert(52+ '273')
alert('52' + '273')
52273
325
52273
52273
52273
1. 기본 문법
숫자와 문자열 자료형 변환
숫자와 문자열 덧셈
문자열 우선!
1. 기본 문법
숫자와 문자열 자료형 변환
숫자와 문자열 뺄셈 / 곱셈 / 나눗셈 ??
1. 기본 문법
숫자와 문자열 자료형 변환
숫자와 문자열 뺄셈 / 곱셈 / 나눗셈 ??
숫자 우선!
1. 기본 문법
자바스크립트 false
5개
1. 기본 문법
자바스크립트 false
0
NaN
''
null
undefined
1. 기본 문법
자바스크립트 false
alert( '' == false)
alert( '' == 0)
alert( 0 == false)
alert( '273' == 273)
1. 기본 문법
자바스크립트 false
alert( '' == false)
alert( '' == 0)
alert( 0 == false)
alert( '273' == 273)
true
true
true
true
1. 기본 문법
자바스크립트 false
alert( '' === false)
alert( '' === 0)
alert( 0 === false)
alert( '273' === 273)
false
false
false
false
2. 조건문
짧은 조건문
true || alert( '범준' )
false || alert(' 명쥬')
2. 조건문
짧은 조건문
true || alert( '범준' )
false || alert(' 명쥬')
3. 반복문
while과 for 반복문 차이
3. 반복문
for in 반복문
배열 , 객체를 다룰 때
for( var i in array){
...
}
4. 함수
익명 함수
fun1();
var fun1 = function(){ alert('foo'); };
var fun1 = function(){ alert('bar'); };
4. 함수
선언적 함수
fun1();
function fun1(){ alert('foo'); };
function fun1(){ alert('bar'); };
4. 함수
선언적 함수
var fun1 = function(){ alert('foo'); };
function fun1(){ alert('bar'); };
fun1();
결과는..??
4. 함수
Hoisting
자바스크립트가 컴파일 될 때,
모든 선언문이 코드의 최상부로 갑니다.
변수의 선언보다 함수의 선언이 더 위로 갑니다.
4. 함수
Hoisting
Why?
4. 함수
Hoisting
재귀
recursion
4. 함수
매개 변수
부족하면?
넘치면?
4. 함수
가변 인자 함수 만들기
function love(){
var length = arguments.length;
if( length == 0){
} else if (length == 1) {
} else {
}
}
4. 함수
가변 인자 함수 만들기
function love(){
var length = arguments.length;
if( length == 0){
} else if (length == 1) {
} else {
}
}
arguments 는 모든 함수에 내장된 변수
4. 함수
가변 인자 함수 만들기
function love(){
var length = arguments.length;
if( length == 0){
} else if (length == 1) {
} else {
}
}
arguments 는 모든 함수에 내장된 변수
4. 함수
IIFE
(function () {
// ...
// ...
// ...
})();
scope 생성
캡슐화
4. 함수
Callback
function CallTenTimes(callback){
for(var i = 0 ; i < 10 ; i++){
callback();
}
}
callTenTimes(function() {
alert('범준이');
});
4. 함수
Callback
매개변수로 함수를 전달합니다.
어디에서 사용? 클로져에서 사용
4. 함수
클로져
function test(name){
var output = 'Hello' + name + '..!';
}
alert(output);
지역 변수는 함수가 생성될 때 생성되고,
사라질 때 사라집니다.
지역 변수를 남겨 두고 싶을 때 클로져를 사용합니다.
4. 함수
클로져
for ( var i = 0 ; i < 3 ; i++) {
setTimeout(function(){
alert(i);
}, 0);
}
4. 함수
클로져
for ( var i = 0 ; i < 3 ; i++) {
setTimeout(function(){
alert(i);
}, 0);
}
3, 3, 3
4. 함수
클로져
for ( var i = 0 ; i < 3 ; i++) {
(function(closed_i){
setTimeout(function(){
alert(i);
}, 0);
})(i);
}
1, 2, 3
자세한 부분은 다음 기회에...
4. 함수
eval()
var x = 10;
var y = 20;
var a = eval("x * y") + "<br>";
var b = eval("2 + 2") + "<br>";
var c = eval("x + 17") + "<br>";
var res = a + b + c;
200
4
27
4. 함수
eval()
var x = 10;
var y = 20;
var a = eval("x * y") + "<br>";
var b = eval("2 + 2") + "<br>";
var c = eval("x + 17") + "<br>";
var res = a + b + c;
쓰지 마세요.
5. 객체
Object
alert( typeof ([]) )
5. 객체
Object
alert( typeof ([]) )
5. 객체
Object
메서드
for in
for ( var key in obj){
var output += key + ' : ' + obj[key] + '\n';
}
5. 객체
Object
with
var output = '';
with( obj ){
output += 'name: ' + name;
output += 'age: ' + age;
output += 'class: ' + class;
}
5. 객체
Object
with
var output = '';
with( obj ){
output += 'name: ' + name;
output += 'age: ' + age;
output += 'class: ' + class;
}
이것도 쓰지 마세요.
6. 생성자 함수, 프로토타입, new
생성자 함수
객체를 생성하는 함수.
function Tree(name) {
this.name = name;
}
var theTree = new Tree('Redwood');
생성자 함수
객체를 생성하는 함수.
function Tree(name) {
this.name = name;
}
var theTree = new Tree('Redwood');
instance
6. 생성자 함수, 프로토타입, new
프로토타입
생성자 함수로 만들어지는 인스턴스들이 같은 함수를 가질 때.
(메모리를 절약한다.)
function person(first, last, age, eyecolor) {
this.firstName = first;
this.lastName = last;
this.age = age;
this.eyeColor = eyecolor;
}
person.prototype.name = function() {
return this.firstName + " " + this.lastName;
};
6. 생성자 함수, 프로토타입, new
String 객체
7. 내장 객체
charAt(position)
concat(args)
indexOf(searchString, position)
replace(regExp, replacement)
slice(start, end)
split(separator, limit)
substr(start, count)
substring(start, end)
toLowerCase()
toUpperCase()
String 객체
7. 내장 객체
charAt(position)
concat(args)
indexOf(searchString, position)
replace(regExp, replacement)
slice(start, end)
split(separator, limit)
substr(start, count)
substring(start, end)
toLowerCase()
toUpperCase()
"Hello BJ, I love you".
String 객체
7. 내장 객체
메서드 체이닝
"Hello BJ, I love you!"
.toLowerCase()
.substring(0,15)
.split(' ')
Array 객체
7. 내장 객체
메서드 체이닝
var array = [0112, 0119, 85, 93];
var sum = 0;
var output = '';
array.forEach(function(element, index, array){
sum += elememt;
output += index + ': ' + element + '\n';
});
Array 객체
7. 내장 객체
메서드 체이닝
var array = [0112, 0119, 85, 93];
var output = array.map(function(element){
return element * element;
});
JSON 객체
7. 내장 객체
JSON.stringify()
JSON.parse()
JSON 문자열 / JavaScript 객체
객체 보조 메서드
7. 내장 객체
Object.keys()
객체의 속성을 배열로 리턴
마지막 챕터
조금만 힘내요~
8. jQuery
getElementsById(id)
getElementsByClass(class)
getElementsByName(name)
8. jQuery
document.querySelector('.test')
document.querySelectorAll('.test')
document.body.innerHTML += '<h1>리얼돌</h1>'
8. jQuery
jQuery는 아닌
Document 객체의 메소드
(DOM 조작 관련)
8. jQuery
후손 선택자
자손 선택자
$(document).ready(function(){
$('body *').css('color', 'red');
$('body > *').css('color', 'green');
});
8. jQuery
.is()
$(document).ready(function(){
$('h1').each(function(){
if( $(this).is('.sangildong')){
$(this).css('background', 'purple');
}
})
});
8. jQuery
.addClass()
.removeClass()
.toggleClass()
8. jQuery
.attr()
$(document).ready(function(){
var src = $('img').attr('src)';
alert(src);
})
8. jQuery
.attr()
$(selector).attr(name, value);
$(selector).attr(name, function(index, val){});
$(selector).attr(object);
Homework
1. url 형식의 string인지 검사하는 함수를 만드세요.
2. email 형식인지 검사하는 함수를 만드세요.
3. 전화번호 입력값을 바르게 바꾸는 함수를 만드세요.
(000-0000-0000 이나 000.0000.0000는 0000000000 로 변환)
4. 조건에 맞는 비밀번호 형식인지 검사하는 함수를 만드세요.
(적어도 한개씩의 특수문자, 문자, 숫자를 포함하고, 같은 문자가 4개 이상 반복되지 않음)
5. 조건에 맞는 아이디 형식인지 검사하는 함수를 만드세요.
(공백, 한글, !@#$,.가 포함되지 않음)
if 조건문은 최소한으로 사용하세요.
정규표현식을 사용하세요.
JavaScript 1
By Ming Kim
JavaScript 1
- 703