홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
okTrot(구독해주세요)
앵콜트로트(구독해주세요)
뽕짝아가씨(구독해주세요)
음악가사 검색
온라이브스토어(앱다운로드)
온라이브(방송등록및청취)
비디오 베스트 50
금영노래방
TJ노래방
유튜브 동영상 다운로드
POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
운.영.자.1대1.상담
FAQ\지원.프로그램
Q&A\고.객.지.원

자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
골때리는 자바스크립트 - Array의 진실 2
3년 전
골때리는 자바스크립트가 10탄까지 나왔습니다. 그냥 내이름 누르고 아이디로 검색하다보면 나옵니다.

한참 배우면서 발견하면서 골때렸던 경험담과 사실을 제가 골때리는 자바스크립트로 기록했는데요. 그렇다고 해서 100% 진실이라고 하기도 뭐합니다. 책도 가끔 오타날 수 있고, 틀린 부분이 있을 수 있거든요.

그래서 오늘은 9.3 탄을 준비했는데. 왜 9.3탄이냐면, 9탄과 3탄의 오류를 수정하면서 개정하는 탄이라 보면 되겠습니다. 골때리는 자바스크립트 9탄은 링크 #1에, 3탄은 링크 #2에 있습니다.

1. new Array(3) == [,,,]

배열 초기자입니다. 둘 다 똑같은 결과가 나오죠. 이미 번역해서 자바스크립트 가이드로 팁텍에도 올라오고 했는데 이게 좀 짧게 짚고 넘어가서 확실히 알아둘 필요가 있기 때문에 이걸 언급하는겁니다.

자, 저렇게 초기화를 날리면 어떤 결과가 나오냐,
[undefined, undefined, undefined]

이렇게 나온다고 생각하시는 분들 없기를 바랍니다. 완전 틀립니다. 비어 있는 배열이 나옵니다. 하지만 문제가 뭐냐? 위처럼 초기화를 한 배열에서 length 속성 찍어보면 3이 나옵니다. 뭐여..

즉, 크기만 3인 뻘 배열이 만들어졌다고 보시면 됩니다. 그래서 다음과 같은 식이 성립됩니다.
(0 in arr) === false

직접 jsfiddle 로 이 둘을 비교해 보세요.
[,,,] != [undefined, undefined, undefined]

다릅니다. 어느 배열이라 해도 같습니다. 일종의 "불능" 자리이죠. 중간에 비어도 마찬가지입니다.
['a', 'b',, 'c']

여기를 보시면 b 와 c 사이에 불능을 집어넣었습니다. 이렇게 되면 어떻게 되냐? 일단 크기는 4입니다. 색인번호가 0부터 3까지 있겠죠? 하지만 2 in arr 하면 false 가 나옵니다. 아예 값을 안집어넣었다는 것이죠.

그럼 이런걸 어따가 써먹냐? 일단 자스 배열은 정적 배열이란 개념이 없습니다. 무조건 기본은 동적 객체입니다. 대신 정적 배열처럼 흉내낼 수는 있죠. 예를들면, 5개 자리만 가질 배열이고, 거기에 값을 부여하고 싶다? 이렇게 하시면 됩니다.
var arr = [,,,,,];
for(var i = 0, len = arr.length; i < len; i++){
    arr[i] = i;
}

이런 식이죠. 고정적인 것처럼 배열 만들어 부여하기. 참 쉽죠?

2. NAME in OBJECT 식

그렇다면 이 식에 대해서 바르게 알고 있는 분을 한번 체크해 보도록 하겠습니다. 먼저 배열 하나 만들어보죠.
var arr = [,,, undefined]; //3개의 자리가 없고, 4번째에 undefined 값을 가진 배열을 만들었습니다.

그렇다면 문제,

(3 in array) && (arr[3] == undefined) 는?

true 입니다. 3번 색인에는 undefined 란 값이 주어졌고, 맞거든요. 그렇다면,

(0 in array) && (arr[0] == undefined) 는?

false 입니다. 네 맞아요. 아예 없기 때문에 undefined라고 나오는 건 맞습니다. 하지만 0번째 자리는 배정받지 않았습니다. 그러니 아예 없죠. 그래서 0 in array 는 false 가 나옵니다. 따라서 자리가 있냐 없냐는 바로 속성명 in 객체 이렇게 따집니다. JSON 조건 처리할때,

'name' in obj 와 obj[name] == 'value' 조건은 다릅니다.

이것은 부울 속성에서 그 성질이 드러나는데요.

체크박스 태그 하나 있습니다. 이건 제거 전에 팁올렸던 겁니다.
<input type="checkbox"/>

여기에 checked 속성만 넣어도 체크되는거 아시죠? 여기에 무슨 값을 넣어도 체크를 합니다. 하지만 checked 속성이 없다면 체크가 안되죠. 이거와 같은 원리입니다. 속성이 있냐 없냐, 그리고 값을 뭘로 부여받았냐 체크하는건 굉장히 중요하죠.

그래서 속성이 존재하느냐 안하느냐를 속성명 in 객체 이렇게 따집니다. 값이 없다는거와 자리가 없다는 차이는 분명히 있다는거 알아두시길.

3. Array.prototype.length 의 진실 2

자, 다시 배열로 넘어오죠. length 속성이 읽고 쓸 수가 있다고 했는데요. 그럼 무슨 역할을 하는건가요?

그냥 자릿수를 표현하는거 그 이상 이하도 아닙니다. 식당 예를 들어보죠., 100명을 수용할 수 있는 자리입니다. 빈 의자가 90개 있고, 10개는 의자가 없습니다. 이렇게 따지시면 됩니다.

따라서 이런 식이 성립됩니다.
var arr = [];
arr.length = 3;
arr == [,,,] //true

그냥 의자없는 3자리가 만들어졌다고 생각하시면 됩니다. 좀더 구체적으로 예를 들어 볼까요?

따라서 ['갑', '을',,, '병', undefined, '정'] 이렇게 배열을 만든다면, 갑 자리와 을 자리, 그옆에 2자리는 의자가 없고, 병, 빈 자리, 정 자리 이렇게 만들어지는거와 같다고 보시면 됩니다. 이해 쉽죠?

납득 ㅇㅇ?

어쨌든, length 는 자릿수를 정하는 거라 보시면 됩니다. 기본적으로 늘리면 늘어난 만큼 의자 놓을 자리가 생긴다 생각하시면 되고, 줄이면 의자 놓을 자리가 사라진다 보시면 됩니다.

4. 배열 삭제하기

배열을 삭제하는 방법이 2가지가 있는데요.
a[3] = undefined;

이건 삭제가 아닙니다. 그냥 undefined 값을 부여할 뿐입니다.

Array.prototype.splice 메소드를 사용하는 방법, 그리고 delete 구문을 이용하는 방법입니다.

이 둘의 차이점은 명확합니다.

먼저 delete 를 보죠. 삭제는 가능합니다.
delete a[2]; //3번째 자리를 삭제합니다. 식당으로 치자면 의자 치우는거죠. 결과는 true 가 나옵니다.

하지만 length 속성에 영향을 미치지 않습니다. 이녀석은 값만 삭제할 뿐, 배열 크기에 영향을 받지 않거든요. 즉, 값만 날리는 것이라고만 아시면 됩니다.

splice(어디부터, 몇개지우고, 뭘채우냐...)

이런 메소드입니다. splice(1,2) 실행하면 두번째자리부터 2개를 삭제한다고 보시면 됩니다. 그리고 그 뒤에 값을 넣으면, 그 빈자리를 값으로 채워지는거죠. 이녀석은 기존 배열을 변경합니다. 이것만 주의하시면 되고, 그리고 반환은 지워진 값들의 배열이 반환됩니다. shift() 나 pop() 과 같이, 지워지고, 변경하고, 그 값을 반환하는 메소드 되겠습니다.

그래서 실질적인 배열 삭제 역할을 하는 메소드라 보시면 됩니다.

쉽죠? 어렵나요? 골때립니까? 자바스크립트에 많이 쓰는 팁입니다. 어려워도 아셔야 합니다. 기본이거든요.

그럼 골때리는 자바스크립트. 골때리는 분을 찾아 골때려 드리도록 하겠습니다. 끝~
추천추천 : 234 추천 목록
번호 제목
3,012
 텍스트 줄바꿈, 글자자르기 CSS
3,011
 jQuery Mobile에서 유용한 코드 10가지.
3,010
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,009
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,008
 [jQuery] jQuery Quick API
3,007
 [ transition ] 링크 hover 색상 변화 속도 조절
3,006
 PHP 5.3.0 에서 사라진 함수들 대체
3,005
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,004
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,003
 jQuery Mobile에서 유용한 코드 10가지.
3,002
 값이 배열 안에 존재하는지 확인하는 in_array함수
3,001
 사용자가 웹브라우저에서 뒤로가기를 했을때 감지하는 방법
3,000
 [jQuery]버튼 활성화, 비활성화
2,999
 jQuery show() / hide() / toggle() 사용법
2,998
 jquery 여러가지 이벤트
2,997
 border-radius 속성
2,996
 네이버 오픈API 음성합성 API 사용하는 PHP 샘플코드
2,995
 UTF8 한글 자르기..
2,994
 iconv 에러 발생시 계속 처리하기 옵션
2,993
 [PHP] 현재 페이지의 도메인 , URL 정보 알아내기.
2,992
 [PHP] 막강 기능 배열..
2,991
 [CSS] - Input clear `X ` 버튼 제거 ( IE, Chrome, Firefox )
2,990
 [Mobile] - 모바일웹 Href 태그속성들
2,989
 [JqueryMobile] - 현재화면의 가로세로 사이즈 구하기
2,988
 [JqueryMobile] - 화면의 가로, 세로 사이즈 구하는 방법
2,987
 jquery로 가로 넓이(width), 세로 높이(height) 자동 조절
2,986
 iframe 높이 jquery로 자동조절하기
2,985
 jQuery 오른쪽 영역의 높이를 왼쪽 영역의 높이와 동일하게 하기
2,984
 jquery에서 테이블 짝수, 홀수 번째 TR 배경색 변경하기
2,983
 jquery에서 테이블에 마우스 오버시 해당 행의 배경색상 변경하기
2,982
 jquery 스크립트내 특정값 확인하기 (디버깅)
2,981
 jquery cookie (jquery.cookie.js)
2,980
 jquery div 기본 넓이, 높이 계산 및 padding, border 포함 하기
2,979
 jquery 다른버전 추가 사용시 충돌 방지 (카페24 스마트디자인 기본내장 jquery 1.4.4 버전과 충돌시 해결방법)
2,978
 특정 페이지 종료시 확인 경고창 출력
목록
추천음악방송
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
앵콜트로트
뽕짝아가씨
작은 음악다방
종합성인가요방
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
Dance&Remix
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요1번지(종합)
뮤직하우스
동요\연변\반주\기타
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
추천가요\POP\기타
최신가요\인기가요
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.