언어/기타
2012.06.12 23:42

[js] 코드 압축 걸음마

조회 수 963 추천 수 1 댓글 2
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
행여 저처럼 발걸음을 갓 떼는 분들께 도움이 될까 올립니다


웹프로그래밍에 있어 중요한것중 손가락에 꼽히는것이 파일크기의 경량화가 아닐까 싶습니다
개중에도 js파일은 그뿐 아니라 코드가 클라이언트에게 그대로 노출되기 때문에 가독성을 떨어뜨리는 면에서도 필요합니다.
사실 본인만의 알고리즘으로 압축해서 사실상 암호화를 하는게 낫지만
어차피 클라이언트에게 소스가 모두 전해지니 복호화 알고리즘도 따라가 일정수준 이상에선 별 의미도 없고
(물론 용량압축면에서 의미없다는건 아닙니다)
..실은 제코가 석자라 패스 ㅠㅠ


우선 가장 기본이자 효율도 좋은 GZip
50% (!) 가량의 효율을 볼때도 허다합니다
게다가 한번 해두면 두고두고 효과를 보니 귀찮아도 꼭 반드시 should mustbe 합시다
php나 여타 파일에도 해당됩니다
는 귀찮으니 검색을 해봅시당 헤헤 
...


그리고 구글에서 제공하는 js압축(?)기
http://closure-compiler.appspot.com/home

주석과 공백을 제거하고 변수명을 짧게, 구조문을 간결하게 해줍니다
추가로 알고리즘 압축을 하는지는 불문하고 반드시 거쳐야할 과정

저처럼 주석을 아예 쓰지않는 스타일이라도 용량이 1-20%정도는 줄어듭니다.
개행이 잦거나 띄어쓰기가 많은경우 크게는 30%까지도 줄어듭디다
다운받아 쓸 수도 있으니 자주 쓰지 싶으면 받아서 두고두고 씁시다


거치고 나서는 압축하기전에 본인만이 할수있는 요약을 추가로 하면 좋습니다.
js파일은 보통 여러파일을 여러군데서 import하기 때문에 
전역변수나 함수명등은 구글압축기가 건드리지 않습니다. 따라서 직접해줘야해유

아 그리고 제경우는 json파싱에 js파일을 하나 받아서 import해쓰는데
jquery나 prototype node등 유명(?)한 파일들은 압축버전이 따로 딸려나옵니다만
많은 파일들이 카피라이트나 설명서등이 주석으로 꽤 딸려오니 반드시 청소하고 씁시다.


압축전엔 반드시 원본파일을 백업하는게 좋습니다만
저처럼 게으르거나 백업본을 분실한 경우엔
압축된 코드를 다시 개행하고 공백넣어주고 하는 프로그램도 있습니다.
제가 직접 손으로 짠거보다 깔끔한게 함정..ㅠㅠ
?
  • profile
    맛난호빵 2012.06.13 01:57
    코드님을 압축시킨다는줄...
  • ?
    2012.06.13 17:11
    엌ㅋㅋㅋㅋㅋㅋㅋㅋ그르지마옄ㅋㅋㅋ

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
701 언어/기타 " 비트맵 이미지/색수 가 부정합니다 " [Solution Matter] file 연지 2007.03.01 796
700 언어/기타 [Orchestral Instrumentation] 4. 비올라 PianoForte 2006.05.03 383
699 언어/기타 [변수를 이용한 액알 랜덤 아이템 분배를 해보자] 부느조로 2005.09.14 740
698 언어/기타 게임성을 좀 더 높여볼까? 다크세이버™ 2006.07.22 706
697 언어/기타 삭제 게이지의달인 2007.06.02 525
696 언어/기타 "빵과 유통기한" EverSmileMan 2006.10.21 1890
695 언어/기타 #pragma warning 피군 2006.08.20 993
694 언어/기타 <응용강좌> 스킬단축키 린쌍 2006.05.20 700
693 언어/기타 <응용강좌> 아이탬토글 -노가다- 린쌍 2006.05.20 609
692 언어/기타 <응용강좌> 키패드 file 린쌍 2006.07.25 350
691 언어/기타 <응용장좌>액션알피쥐.몬스터이벤트 린쌍 2006.05.22 901
690 언어/기타 '에피소드'형식이 아닌 '화' 형식의 시나리오는 어떨까요? 우드록맨 2007.04.09 1529
689 언어/기타 '켄타'의 Vnap 왕초보강좌 [0.Vnap이란?] file 켄타 2006.07.25 639
688 언어/기타 '켄타'의 Vnap 왕초보강좌 [1. Vnap의 기본상식!] file 켄타 2006.08.14 932
687 언어/기타 (2003) 연속공격 버프 스킬로 '공격' 커맨드의 활용도를 늘려보자. 땡중 2007.11.17 1924
686 언어/기타 -_- 훗... 비법따위 이정도로.. 예화 2005.12.09 355
685 언어/기타 -ㅅ- 누가 아이디어좀 제공해주세요. 린쌍 2005.11.26 418
684 언어/기타 0.0 [S's-S] 2006.01.05 277
683 언어/기타 0.0초 대기시간 분석 (전에 올렸는데 없어졌군요) [S's-S] 2006.09.01 397
682 언어/기타 0.0초 대기시간 분석 (전에 올렸는데 없어졌군요) [S's-S] 2006.09.01 394
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 36 Next
/ 36






[개인정보취급방침] | [이용약관] | [제휴문의] | [후원창구] | [인디사이드연혁]

Copyright © 1999 - 2016 INdiSide.com/(주)씨엘쓰리디 All Rights Reserved.
인디사이드 운영자 : 천무(이지선) | kernys(김원배) | 사신지(김병국)