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

자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
JavaScript로딩을 최적화하여 페이지 렌더링 속도를 빠르게 하는 6가지 방법
3년 전
1. HTTP Request를 줄이기 위해 JavaScript 파일은 한개로 통합합니다.

웹페이지 렌더링을 빠르게 하는 방법 중 하나는 HTTP 요청 수를 줄이는 것입니다. 1개의 웹페이지를 로딩한다고 해도 HTML문서파일, 이미지, 스크립트등을 다운로드하기 위해 웹서버와 브라우저(클라이언트)간에 몇 번이나 데이터를 주고받고 있습니다.

HTTP 요청 수를 줄이기 위해서 여러 개로 나누어진 JavaScript를 한개의 파일로 정리해야 합니다.

[나쁜 예]



<script src="http://www.example.com/menu.js"></script>
<script src="http://www.example.com/ajax.js"></script>
<script src="http://www.example.com/nav.js"></script>
<script src="http://www.example.com/tools.js"></script>
<script src="http://www.example.com/footer.js"></script>
<script src="http://www.example.com/others.js"></script>



[좋은 예]


<script src="http://www.example.com/combined-all.js"><</script>


위 예에서는 파일 1개로 합쳐서 6번에 걸쳐 발생하는 HTTP 요청을 한번으로 줄일 수 있습니다. 접속자수가 많은 사이트라면 효과를 볼 수 있습니다.




2. CSS참조 태그를 JavaScript참조태그보다 먼저 추가합니다.

HTML head섹션에는 스타일시트 참조를 먼저 작성하고 그 다음에 JavaScript 참조를 추가합니다.

[나쁜 예]


<head>  <script src="http://www.example.com/nav.js"></script>
  <script src="http://www.example.com/tools.js"></script>
  <script src="http://www.example.com/footer.js"></script>
  <link rel="stylesheet" type="text/css" href="stylesheet1.css" />
  <link rel="stylesheet" type="text/css" href="stylesheet2.css" />
</head>



[좋은 예]


<head>  <link rel="stylesheet" type="text/css" href="stylesheet1.css" />
  <link rel="stylesheet" type="text/css" href="stylesheet2.css" />
  <script src="http://www.example.com/nav.js"></script>
  <script src="http://www.example.com/tools.js"></script>
  <script src="http://www.example.com/footer.js"></script>
</head>



JavaScript는 로딩을 하기 시작하면 그 로딩이 완료될 때까지 다음 코드 로딩을 하지 않습니다. 그래서 이런 경우에 대기 시간이 발생하게 됩니다. 반면에 스타일시트 읽기는 여러 개를 동시 로딩할 수 있고 모두 읽어지지 않아도 JavaScript 파일등의 다른 파일을 읽을 수 있습니다.

추가적으로는 여러개의 스타일시트를 참조할 동안에 JavaScript참조를 중간중간에 넣고 사용한다면 더 속도 저하가 생길 가능성이 있습니다.




3. 프로토콜을 생략합니다.

JavaScript 외부 파일을 나타내는 URL로부터 http: 또는 https:라는 프로토콜을 생략합니다. 생략하여 파일 크기를 조금이라도 줄일 수 있습니다.

[나쁜 예]


<script src="http://www.example.com/scripts/javascript.js"></script>


[좋은 예]


<script src="//www.example.com/scripts/javascript.js"></script>


프로토콜이 생략되어 있는 경우, 해당 페이지 렌더링에 사용되고 있는 프로토콜이 동적으로 적용됩니다. 즉, https:를 사용하여 사이트를 접속중이라면, 자동적으로 https:가 사용됩니다.

참고로 JavaScript뿐만 아니라, CSS, 이미지든 프로토콜을 URL에서 제외하고 사용할 수 있습니다. 단, 생략할 경우, 외부 리소스를 사용할 수 없을 수 있으므로 외부 리소스를 사용할 경우에는 프로토콜을 사용합니다.




4. script요소의 type속성은 생략합니다.

HTML5 페이지일 경우로 제한되지만, script요소에 사용하던 type속성(type="text/javascript")를 생략합니다. HTML5에서는 script요소의 type속성 초기값이 "text/javascript"로 되어 있기 때문입니다. 생략하면 파일크기를 약간 줄일 수 있게 됩니다.

[나쁜 예]


<script src="//www.example.com/scripts/javascript.js" type="text/javascript"></script>


[좋은 예]


<script src="//www.example.com/scripts/javascript.js"></script>


추가적으로 HTML5에서는 style요소의 type속성도 생갹할 수 있습니다.




5. Expires헤더로 캐쉬기간을 길게 설정합니다.

웹브라우저는 1개의 파일이라도 다운로드한 데이터는 로컬에 캐쉬합니다. 다시 같은 데이터가 필요할 경우에 로컬에 캐쉬가 되어 있다면, 서버에 요청을 보내지 않고 캐쉬데이터를 이용합니다. 이렇게 되면, 자신이 가지고 있는 데이터를 사용하기 때문에 응답이 빨라집니다.

다만 캐쉬는 기간이 지나면 삭제되기 때문에,  Expires라는 HTTP헤더를 사용하여 캐쉬기간을 늘릴 수 있습니다. 웹서버가 Apache라면, .htaceess 또는 httpd.conf로 Expires헤더를 설정하면 JavaScript의 캐쉬시간을 관리할 수 있습니다.

예로 아래와 같이 작성할 수 있습니다.



<IfModule mod_headers.c>
<IfModule mod_expires.c>
ExpiresActive On
ExpiresByType text/javascript "access plus 4 weeks"
ExpiresByType application/x-javascript "access plus 4 weeks"
ExpiresByType application/javascript "access plus 4 weeks"
</IfModule>
</IfModule>






JavaScript 파일을 처음 로딩한 다음부터 4주가 지나면 캐쉬 기간이 끝나 삭제됩니다. 즉 4주간 로컬에 캐쉬가 남아 있다는 소리입니다. 기간 설정 방법은 웹서버마다 틀리기 때문에 서버별로 확인하기 바라며, Apache의 경우, 이 문서를 참고합니다.

추가적으로 서버에 mod_expires모듈이 설치되어 있지 않으면 사용할 수 없으므로 주의해야 합니다.

참고로 JavaScript뿐만 아니라, 다른 콘텐츠 캐쉬 기간 제어도 Expries헤더로 설정할 수 있습니다.


ExpiresByType image/gif "access plus 4 weeks"ExpiresByType image/jpeg "access plus 4 weeks"
ExpiresByType image/png "access plus 4 weeks"



파일 타입(MIME타입) 지정은 apache문서를 읽어보기 바라며, JavaScript파일타입은 문서에 쓰여있지 않아 조사해보니 몇 개가 더 있는 것 같습니다. 서버 환경에 따라 다르며 일반적으로 사용되고 있는 3가지 종류가 있습니다. 그런데 원래 포스팅된 글에는 이 내용이 없어서 보충합니다.




캐쉬기간을 어느정도 설정할지가 문제이지만, 이는 본인스스로가 생각해서 설정해야 합니다. 여기서 설정된 4주가 합리적이지 않을 수 있습니다. (참고로 RFC에 따르면 1년 이상 기간을 지정해서는 안됩니다)

또한 httpd.conf가 아닌 .htaccess를 사용한다면, '4 weeks'보다 성능이 좋아질지도 모릅니다. 다만 주의해야 할 점은 거의 업데이트가 없는 정적인 파일에 Expires헤더를 사용하는 것입니다. 업데이트해도 캐쉬를 사용해 버리기 때문에, 브라우저에 남아 있는 오래된 데이터가 사용되어 버리기 때문입니다. 업데이트햇을 경우, 파일명을 변경하는 것이 좋다고 봅니다.




캐쉬 관리로는 프록시 캐쉬를 사용하는 방법도 존재합니다. 원문 글내용을 살펴보면 간단하게 이에 대한 방법이 나오므로 참고하길 바람니다.  JavaScript이외에 이미지나 CSS등의 정적인 파일도 포함되며 보관기간은 4주간으로 설정되어 있습니다.

주의해야 할 점은, CSS와 JavaScript를 Cache-Control헤더로 캐쉬할 경우, 특정 서버에 따라 프록시 서버 버그가 있어 제대로 기능동작을 하지 않는 경우도 있습니다.




6. 주석을 삭제합니다.

JavaScript 파일 내에 작성되어 있는 불필요한 주석은 모두 삭제합니다. 파일 크기가 작아져 웹브라우저로딩이 빨리집니다. HTML파일이나 CSS파일에서도 주석 삳제는 효과적입니다. 다만, 확 느낄 정도로 속도가 높아질지는 모르겠습니다. 해두면 좋다고 인식하고 있으면 될 것 같습니다.




이상으로 웹사이트에서 JavaScript 로딩을 최적화하여 웹페이지 렌더링 속도를 개선하는 방법을 정리해 보았습니다. 최소한 JavaScript 파일을 합쳐서 파일 크기를 줄이고 HTTP요청/응답을 최대한 줄어보려는 방법을 생각해보기 바랍니다.
추천추천 : 240 추천 목록
번호 제목
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.