기본 콘텐츠로 건너뛰기

Gruntfile의 구조와 사용법

Gruntjs를 사용한다고 하는것은 gruntfile.js를 다룰 줄 안다고 하는 것과 마찬가지로 gruntfile.js는 중요합니다. 중요하다고 해서 배우기가 어렵다는 말은 아닙니다.
개인의 차이는 있겠지만 보통 1~2일이면 개념을 이해 할 수 있고 1주일 정도면 구글링을 하면서 Gruntjs를 사용할 수 있을 정도로 어렵지 않습니다.

이전 포스팅에서 Gruntjs의 소개와 설치법을 작성했으니 완전 초보자이시면 이전 포스팅을 먼저 보는 것이 도움이 될것 같습니다.

gruntfile.js의 구조와 사용법

gruntfile.js의 가장 기본적인 구조는 아래와 같습니다.
1. 프로젝트의 구성, 2. 사용한 플러그인 로딩, 3. 실행 명령어의 3개의 분류로 구성되어 있으며 각각 영역별로 설명을 하도록 하겠습니다.

module.exports = function(grunt) {

  // 1. 프로젝트의 구성
  grunt.initConfig({

    // package.json의 정보를 불러옴
    pkg: grunt.file.readJSON('package.json'),

    // uglify 플러그인(패키지)의 옵션을 정의 함
    uglify: {
      build: {
        src: 'src/<%= pkg.name %>.js',
        dest: 'build/<%= pkg.name %>.min.js'
      }
    }

  });

  // 2. 사용한 플러그인 로딩(먼저 npm으로 설치를 해야 함) 
  grunt.loadNpmTasks('grunt-contrib-uglify');

  // 3. 실행 명령어 (명령창에서 grunt 명령으로 실행됨)
  grunt.registerTask('default', ['uglify']);

};

gruntjs사이트에서 발췌

1. 프로젝트의 구성

프로젝트의 구성은 module.exports = function(grunt) { ... } 로 javascript의 Function형태로 작성하고 모듈을 exports하여 외부에서 실행시킬 수 있게 되어 있습니다.

module.exports = function(grunt) {

};

▲ 예) gruntfile.js의 모든 내용은 위의 모듈 내에 작성을 해야 합니다. 위의 모듈내에 작성된 내용은 node js의 명령어창(주로 window의 Dos창)에서 명령어로 실행을 시킬 수 있습니다.

Tastk 구성 정의

grunt.initConfig({ ... }) 안에 사용할 Task(플러그인)들을 명시하고 옵션을 지정합니다. Task(플러그인)들의 작성 순서는 상관없이 없으며 설치된 각 Task(플러그인)을 어떻게 사용할지에 대한 구성을 정의 합니다. 예를들면, 원본파일은 어느 폴더에 있는 파일을 참조할지, 처리는 어떻게 할지, 그리고 처리하고 난 결과물은 어디 폴더에 저장 할지 등등.. 설정을 각 Task별로 정의를 합니다.

grunt.initConfig({ 

    // uglify 플러그인(패키지)의 옵션을 정의 함
    uglify: {
      build: {
        src: 'src/<%= pkg.name %>.js', // 소스폴더 위치
        dest: 'build/<%= pkg.name %>.min.js' // 결과를 저장할 폴더와 파일명
      }
    }

 })

▲ 여기서는 샘플로 uglify라는 Task(플러그인) 하나만 정의 했지만 실제로는 많은 플러그인들을 나열하여 정의합니다.

uglify 플러그인에 대해서 간단히 설명을 하면....

uglifyjavascript를 압축해 주는 플러그인입니다. 압축이라 함은 javascript 코드에서 빈공간과 줄바꿈, 주석 등.. 불필요한 모든 요소들을 제거해 줍니다. 그래서 결과 파일을 봤을 때는 소스코드가 그냥 한줄로 아주 길게 늘어져있는 코드만 보여 집니다.

uglifybuild를 실행시키면 src에 지정된 url에 있는 javascript파일 들에 대해서 모두 uglify처리를 합니다. 그리고 dest에 지정된 url에 결과 파일을 저장합니다. 보통은 같은 폴더 안에 .min을 붙혀서 저장하는 경우가 일반적입니다.

2. 사용한 플러그인 로딩

grunt.initConfig({ ... })에 지정한 플러그인들을 사용하기 위해서는 먼저 아래와 같이 플러그인을 불러와야 합니다. 사용한 모든 플러그인을 로딩 해야 합니다.
샘플에는 uglify만 사용했기 떄문에 grunt.loadNpmTasks('grunt-contrib-uglify');만 로드하면 되지만 그냥 샘플로 아래에 몇 개를 더 추가해 봤습니다. 이런식으로 사용한 플러그인들은 아래쪽으로 작성하여 로딩을 시켜줘야 합니다.

  grunt.loadNpmTasks('grunt-contrib-uglify');
  grunt.loadNpmTasks('grunt-contrib-imagemin'); // 이미지를 옵션에 따라 압축함
  grunt.loadNpmTasks('grunt-contrib-coffee'); // coffee 스크립트로 작성된 소스를 javascript로 변화시켜줌
  ...
참고로 플러그인 명이 contrib가 들어가 있는 것은 Grunt Team에서 제작한 것이므로 공신력이 있다고 보시면 됩니다.

3. 실행 명령어

플러그인을 정의 했고, 로딩을 했으면 마지막으로 플러그인들을 순서대로 실행시켜는 명령어 뭉치를 작성하애 합니다.
grunt.registerTask('default', ['']); 라는 명령어 뭉치로 작성을 한 후 명령어 창에 grunt 명령어를 실행시키면 지정된 순서대로 실행이 됩니다. 상황에 따라 여러개의 명령어 뭉치를 작성해놓고 골라서 실행시켜도 됩니다.

  grunt.registerTask('serve', [
    'uglify',
    'imagemin',
    'coffee'
  ]);
  ...

▲ 명령어 창에 grunt serve라는 명령어를 입력했을 때, 먼저 uglify가 실행되고 두번쨰로 imagemin가 실행되고 세번쨰로 coffee가 자동으로 실행됩니다.

  grunt.registerTask('build', [
    'coffee'
    'uglify',
    'imagemin',
  ]);
  ...

▲ 명령어 창에 grunt build라는 명령어를 입력했을 때, 먼저 coffee가 실행되고 두번쨰로 uglify가 실행되고 세번쨰로 imagemin가 자동으로 실행됩니다.

  grunt.registerTask('default', [
    'imagemin',
    'coffee'
    'uglify',
  ]);
  ...

▲ 명령어 창에 grunt라는 기본 명령어를 입력했을 때, 먼저 imagemin가 실행되고 두번쨰로 coffee가 실행되고 세번쨰로 uglify가 자동으로 실행됩니다.

다음 포스팅에는 Gruntfile.js주요 플러그인에 대해서 소개하도록 하겠습니다.

댓글

이 블로그의 인기 게시물

CSS에서 ellipsis('...')를 처리하는 방법

이번에 ellipsis에 대해 정리해 보도록 하겠습니다. 보통 게시판 리스트의 제목부분이 길어질 경우 php나 jsp등의 프로그램단에서 일정 글자수 이상이 되는 것에 대해 '...'으로 마무리 하는 경우가 많은데요.. 이것을 프로그램이 아닌 CSS만 가지고도 처리할 수 가 있습니다. 한줄라인 글자수 제한 한줄 라인 글자수 를 제한하는 방법은 아래와 같습니다. <div class="txt_line">통영의 신흥보물 강구안의 동쪽벼랑인 동피랑의 벽화마을을 다녀왔다</div> .txt_line { width:70px; padding:0 5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; } Block레벨 테그에서만 적용됨. overflow:hidden : 넓이가 70px를 넒어서는 내용에 대해서는 보이지 않게 처리함 text-overflow:ellipsis : 글자가 넓이 70px를 넘을 경우 생략부호를 표시함 white-space:nowrap : 공백문자가 있는 경우 줄바꿈하지 않고 한줄로 나오게 처리함 (\A로 줄바꿈가능) 멀티라인 글자수 제한 멀티라인에 대해서 글자수를 제한하는 방법은 아래와 같습니다. <p class="txt_post">통영의 신흥보물 강구안의 동쪽벼랑인 동피랑의 벽화마을을 다녀왔다.&nbsp; 비도 추적추적 내리고 일정상 늦으막해서 그런지 사람이 많지는 않았다. 덕분에 보통때는 한참을 기다려야 겨우 날개달린 사진을 찍을 수 있었을 텐데, 이번에는 바로 천사날개를 달고 사진을 찍을 수 있는 행운까지 얻었다. 이번이 동피랑 벽화마을 방문 3번째인데 예전에 왔을때에 비해서 벽화가 많이 바뀌어 있었다</p> .txt_post { overflow: hidden; text-ove...

Google 스프레드시트로 구글캘린더에 일정 연동하는 방법

저는 구글 제품을 많이 사용하는 편입니다. 제 주력 캘린더도 Google 캘린더 고요. 이번에 모임의 임원을 맡게 되면서 회원들의 생일을 캘린더에 등록해야 할 일이 생겼어요. 그냥 하나하나 등록을 하는 도중 "내가 지금 뭐하고 있나.." 라는 자괴감이 들기 시작했어요. 구글 시트에 있는 날짜 정보(생일)을 한 번에 쉽게 일괄 등록할 수는 없을까라는 생각이 뇌리를 스쳤습니다. 그래서 찾아봤더니.. 약간의 매크로 프로그램을 작성하면 가능할 것 같더라고요. 그래서 열심히 개발을 해봤습니다. 1시간이면 등록할 것을 8시간 걸려서 프로그램을 짜 봤어요. 결과적으로는 더 비효율적이었네요. ㅠㅠ 그러나... 나에게는 비효율 적이었지만 이코드를 공개하면 다른 사람에게는 큰 도움이 될 수 있겠구나 생각을 하고 코드를 공개해 보려고 합니다. 준비물 준비물은 Google 스프레드시트, Google 캘린더만 있으면 돼요. 당연히 무료고요. Google 캘린더 먼저 Google 캘린더를 만들거나 사용하고 있는 캘린더를 준비합니다. 적용하기 원하는 캘린더의 우측의 ... 를 클릭하고 설정 및 공유 를 선택합니다. 캘린더 ID를 잘 기억해 놓습니다. 나중에 이 ID를 활용할 예정입니다. Google 스프레드시트 회원생일 스프래드시트 공유 Google 스프레드시트로 명단과 생일을 작성합니다. ▲ 위와 같이 작성을 하면 되고 중요한 사항은.. 생년월일 이 구글 시트의 날짜 형식에 맞아야 합니다. 그리고 갤린더등록 , 캘린더상태 의 항목은 필수로 있어야 합니다. 캘린더등록 : 캘린더에 등록할지 제거할지를 표시 (ADD / DEL) 캘린더상태 : 현재 캘린더에 해당 항목이 적용되었는지 확인 (Y / ' ') 매크로 프로그램 작성하기 기본적인 준비는 끝났습니다. 이제부터 Apps Script를 제작하고 트리거를 등록하면 됩니다. Apps Script 작성하기 Apps Script 는 구글 제품에 대...

Google캘린더(달력)에 대한민국 휴일 표시하기

구글 캘린더에 대한민국 휴일을 표시하는 설정에 대해서 소개합니다. 네이버 달력이라면 그냥 기본으로 나오겠지만 구글캘린더의 경우는 별도의 설정을 해 주어야 합니다. 휴일의 표시는 각 나라의 휴일을 구글에서 미리 작성해 놓은 것을 내 캘린더에 불러와 적용하는 방식으로 되어 있습니다. 대한민국 공유일 표시하기 먼저 설정화면으로 이동합니다. 캘린더 화면의 우측상단의 설정 아이콘을 클릭합니다. 메뉴 중 설정 을 클릭합니다. 설정화면 중 좌측 메뉴에서 캘린더 추가 메뉴를 선택합니다. 관심분야와 관련된 캘린더를 선택합니다. 지역 공휴일의 모두 둘러보기 를 선택하면 각나라의 휴일을 선택할 수 있습니다. 우리는 대한민국의 휴일 을 선택합니다. 캘린더에서 공휴일 보기 대한민국 휴일에 대한 설정을 했다면 이제 보기 좋게 표시하면 됩니다. 설정을 정상적으로 했다면 좌측메뉴에 대한민국의 휴일 이라는 캘린더가 보입니다. 캘린더명의 우측끝에 더보기 아이콘 을 선택합니다. 색상을 빨간색으로 선택합니다. (보통 공휴일은 빨간색이므로.. ㅎ) 그러면 캘린더에 휴일의 명칭이 빨간색 으로 표시되게 됩니다. 감사합니다.