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

자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
자바스크립트 성능 향상을 위한 3가지 팁
11년 전

예전에 자바스크립트는 단순히 배경색을 바꾸거나 입력형식을 검사하는 등의 용도로 사용되었으나 지금은 DHTML과 결합하여 상당히 덩치가 커지게 되었다. 그래서 이제는 성능이라는 것을 고려해야 한다. 이번장에서는 자바스크립트의 성능을 향상시킬수 있는 일반적인 방법 3가지를 살펴보겠다.

개체들을 캐싱시켜라...

자바스크립트의 성능을 향상시킬수 있는 방법중 하나는 개체를 캐싱시키는 것이다. 다음과 같이 반복적인 작업을 수행하는 스크립트가 있다고 하자.

 

<script language="JavaScript1.1">
for (i=0;i<document.images.length;i++)
document.images[i].src="blank.gif"
</script>

위의 예에서 document.images라는 개체는 여러번 불리워지고 있다. 각각의 루프가 돌때마다 document.images가 두번씩 읽혀지고 있다. 우리가 불러들여야 되는 것은 images 뿐이다. 하지만 여기서는 document를 거쳐서 images에 도달하고 있다. 이를 조금 개선해보자.

 

<script language="JavaScript1.1">
var theimages=document.images
for (i=0;i<theimages.length;i++)
theimages[i].src="blank.gif"
</script>

이제 성능향상이 되었다는 것이 보일것이다. 개체를 캐싱시키라는 뜻은 반복적으로, 그리고 순차적으로 접근되어가는 개체를 사용자가 정의한 변수에 넣어서 사용하라는 것이다. 위의 예에서 document.images를 theimages라는 변수에 넣었다. 그리고 루프에서 이를 사용함으로서 document -> images가 아닌 images만 액세스하게 되었다.

이와 같은 사용예는 document.all.someobject , document.layers.somelayer 등에 사용할 수 있다.

스크립트를 캐싱하라...

성능을 향상시키는 또 다른 방법은 스크립트를 통채로 캐싱시키는 것이다. 스크립트를 js파일에 저장하고 이를 사용하면 페이지 Reload나 두번째 방문시 이후는 캐시에서 이를 꺼내 사용하게 된다.

 

<script src="imagescript.js"></script>

이러한 스크립트 캐싱은 스크립트의 양이 많거나 여러 페이지에 삽입되어 사용할 경우 좋은 효과를 낼 수 있다.

상황에 맞는 개체를 사용하라...

각각의 개체를 상황에 맞게 사용하여야 한다. 다음의 두 동적 속성을 보자.

 

-object.innerText
-object.innerHTML

첫번째보다 두번째 속성이 더 자원을 많이 사용하게 된다. <DIV>나 <SPAN> 안에 텍스트 문자들만 들어가게 한다면 innerText를 사용하여 좋은 성능효과를 볼 수 있을 것이다. 이와 같은 것으로 CSS의 Display와 Visibility가 있다. 역시 후자에 비해 전자가 자원소모가 더 많다.

마무리

많은 사람들이 자바스크립트가 C나 자바와 같은 덩치 큰 언어가 되는 것은 시간문제라고 생각하고 있다. 그렇다면 이제 성능에 대하여 한번쯤 다시 생각해보아야 할 때가 아닌가 생각한다.

추천추천 : 163 추천 목록
번호 제목
3,015
 iframe 높이 100% 맞추기
3,014
 curl 함수를 이용한 HTTP REFERER 변경
3,013
 윈도우10 시스템 파일 및 Dism 검사
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)
목록
인기절정뽕짝파티
트로트재생목록
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

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