언어/기타
2012.06.12 23:42

[js] 코드 압축 걸음마

조회 수 971 추천 수 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
    엌ㅋㅋㅋㅋㅋㅋㅋㅋ그르지마옄ㅋㅋㅋ

  1. HeveyMetal 200% 설명보충 (웃김-_-)a

    Date2005.06.05 Category언어/기타 ByMoonMarsh Views1018
    Read More
  2. 온라인 탈출&추리게임

    Date2006.05.10 Category언어/기타 By첫비 Views1017
    Read More
  3. Ham Engine Library : 키보드 입력과 마우스 입력 처리

    Date2005.08.03 Category언어/기타 By하앙e Views1017
    Read More
  4. 선행처리기 지시어. (#???)

    Date2006.09.30 Category언어/기타 By연지 Views1015
    Read More
  5. 이번에도 잡담입니다만-_-;;

    Date2007.01.01 Category언어/기타 By아란 Views1014
    Read More
  6. 성향게이지

    Date2005.09.15 Category언어/기타 By사토루 Views1012
    Read More
  7. 스킬의 레벨제 도입

    Date2005.09.16 Category언어/기타 Byll김ll밥말이™ Views1009
    Read More
  8. 액알도 전투를 좀더 재밋게!

    Date2006.04.01 Category언어/기타 By다크아머 Views1005
    Read More
  9. [C++] template의 활용법

    Date2007.01.21 Category언어/기타 ByZeprod Views1004
    Read More
  10. 장소 이동을 하지 않고 집으로 들어가보자....

    Date2005.09.04 Category언어/기타 By야미토츠바사 Views1003
    Read More
  11. #pragma warning

    Date2006.08.20 Category언어/기타 By피군 Views993
    Read More
  12. 그저 비주얼 베이직에 낚인 것에 대한 잡담

    Date2006.12.27 Category언어/기타 By아란 Views992
    Read More
  13. 대기

    Date2007.01.08 Category언어/기타 By가다없는 Views992
    Read More
  14. 제 1 부 ! 도전 ! 나도 게임 만들 수 있다!

    Date2006.05.23 Category언어/기타 By다크세이버™ Views990
    Read More
  15. 액알 스킬 팁

    Date2005.09.11 Category언어/기타 By다크세이버™ Views981
    Read More
  16. 속성 작명법

    Date2005.10.16 Category언어/기타 By앞만보맨 Views977
    Read More
  17. 간단한 점프를 설정해볼까 ?

    Date2005.08.02 Category언어/기타 By다크세이버™ Views977
    Read More
  18. [js] 코드 압축 걸음마

    Date2012.06.12 Category언어/기타 By Views971
    Read More
  19. 오늘 개강.

    Date2006.08.29 Category언어/기타 By아란 Views967
    Read More
  20. Date2006.08.25 Category언어/기타 By초코군 Views966
    Read More
Board Pagination Prev 1 ... 7 8 9 10 11 12 13 14 15 16 ... 36 Next
/ 36






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

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