언어/기타
2012.06.12 23:42

[js] 코드 압축 걸음마

조회 수 962 추천 수 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 언어/기타 ROAM에 관련된 자료. 174 피군 2006.08.08 24847
700 언어/기타 바실리어트 1. 시작하기 전에 Vermond 2007.07.03 6070
699 언어/기타 바실리어트 3. 메인화면 제작 Vermond 2007.08.14 5956
698 언어/기타 연애 시뮬레이션 만들기 2 2 Vermond 2006.08.02 5280
697 언어/기타 [css, js] form - select안의 option들에 스타일 적용하기 4 file 2012.04.28 5189
696 언어/기타 바실리어트 2. 스크립트 입문 1 Vermond 2007.07.05 4976
695 언어/기타 바실리어트 4. 소스 준비 Vermond 2007.08.14 4622
694 언어/기타 액션게임만들기(Action Game Maker) HELP파일 번역 1 다프트캣 2010.08.19 4095
693 언어/기타 자동 길찾기 기능을 만들어보자 1 file Black-☆ 2010.08.19 3485
692 언어/기타 잠입액션에서 적의 시야 설정하기 (예제有) 3 file rhj 2009.05.06 3316
691 언어/기타 신개념 마법시스템? 1 [S's-S] 2006.07.25 3170
690 언어/기타 바람의나라 - 쇄혼비무 , 초혼비무 액알의초보 2006.07.04 2977
689 언어/기타 게임을 시작한다음 튕기게 해보자(?) 4 file 켈군 2009.02.04 2943
688 언어/기타 Unity3D 순수악 2011.03.29 2834
687 언어/기타 게임,개발기획의 기초 5 Grand 2011.08.01 2803
686 언어/기타 알만툴에서 윤년표현 file 엘류트 2009.04.17 2801
685 언어/기타 커맨드입력 4 엘류트 2009.04.17 2795
684 언어/기타 [THDO]판화 세계지도제작 스크립트. file 협객 2007.06.25 2703
683 언어/기타 MSN 주소를 알려주세요. MrGeek 2006.09.13 2677
682 언어/기타 0.0초를 다룰때 조심할점 3 A. 미스릴 2009.03.13 2646
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(김원배) | 사신지(김병국)