기본 콘텐츠로 건너뛰기

Grunt 소개와 설치방법

Node js의 탄생으로 인해 javascript진영이 비약적인 발전을 이루고 있으며 그러한 발전에 견인차 역활을 한 Grunt라는 것이 있습니다. 이러한 프레임워크를 javascript Task기반 빌드 Tools이라고 하는데 과연 이것이 무엇인지, 그리고 어떻게 설치하고 사용하는지에 대해 포스팅을 하려고 합니다.

그런트로고

Gruntjs란 무엇인가.

Grunt 또는 Gruntjs라고 하며 인터넷을 검색하면 Task기반 빌드 툴이라고 나옵니다. 풀어서 설명을 하면...
Node js를 기반으로 하고있는 무수한 패키지들 중에 프로젝트에서 필요한 패키지들을 설치하고 그 패키지들을 미리 설정한 순서와 옵션에 맞게 자동으로 명령어를 실행시켜주는 Tool이라고 보면 됩니다.

마치 Desktop컴퓨터의 .bat 배치파일과 동일한 역활을 합니다.

Gruntjs를 사용하기 위해서는 먼저 Node js가 설치되어 있어야 하고 프로젝트가 지정되어 있어야 합니다. Node js가 설치되면 npm(node package manager)도 자동으로 설치가 되는데 이 npm으로 gruntjs를 설치하면 됩니다.

프로젝트 지정이란 그냥 프로젝트명의 폴더 생성 이라고 보면됩니다.

Grunt 설치

Node js 설치

당연한 이야기겠지만 Node js를 먼저 설치해야 합니다. Nodejs는 한글버전도 있기 때문에 설치가 어렵지는 않습니다.
NodejsWindows, macOS, Linux 등 대부분의 OS를 지원하며 설치방법은 해당 홈페이지를 참조하셔서 설치하시면 되고 여기서는 생략하도록 하겠습니다.

Windows사용자라면 그냥 홈페이지에서 설치파일을 다운로드 받아서 설치하면 됩니다.

Node js

Grunt-cli 설치

Nodejs가 설치가 되었다면 그 다음으로 grunt-cli를 설치해야 합니다. grunt-cligrunt Command Line Interface의 약자로 명령어 창(Dos화면)에서 명령어를 실행 할 수 있게 해줍니다. 다시말하면 gruntjs의 명령어 패키지라고 보면 됩니다.
grunt-cli는 일반적으로 프로젝트(local)에 설치하기보다는 컴퓨터 전체(global)에 설치를 합니다.

-g는 프로젝트에 설치하는 것이 아니라 global로 설치하겠다는 옵션입니다.

아래의 명령어는 간단하게 npm으로 grunt-cli를 설치하는 명령어입니다. 물론 온라인에 연결이 되어 있어야 합니다.

npm install -g grunt-cli

프로젝트 생성

이제 Grunt를 사용하기 위해서는 먼저 프로젝트를 생성해야 합니다. 프로젝트 생성이라 함은 별거 없이 그냥 프로젝트 명의 폴더만 하나 만들어 주면 됩니다. 그렇게 만든 폴더에 package.json파일과 Gruntfile.js만 있으면 프로젝트의 root folder가 됩니다.

package.json

package.json 은 프로젝트의 정보와 버전, 설치된 javascript 패키지리스트 등.. 프로젝트의 전반적인 내용을 기록하고 있는 파일입니다. package.jsongrauntjs에 특화된 파일은 아니고 Node js에서 사용하는 것을 Gruntjs 에서도 사용하는 것이라 보는 것이 맞습니다. 만약 기존에 미리 설정된 package.json이 있다면 npm install이라는 명령어로 package.json에 기록되어 있는 javascript 패키지를 일괄 설치 할 수 있습니다. package.json파일이 잆다면 명령어 창에 npm init로 문답형식으로 새로 생성할 수 있습니다.

npm init

gruntfile.js

Gruntjs에 특화된 파일입니다. Gruntjs를 사용한다는 것은 이 gruntfile.js를 다루는 것이라고 보면 됩니다. 이 파일에는 어떤 패키지를 어떤 옵션으로 언제 실행 할 것인가에 대해 기록을 합니다. 그리고 grunt 또는 grunt serve 또는 grunt build등의 명령어로 실행시키도록 되어 있습니다. 이 명령어 조차도 gruntfile.js에서 지정을 합니다.
파일이 없다면 그냥 gruntfile.js 파일명으로 파일을 새로 만들면 됩니다.

Grunt 설치

grunt-cli가 명령어 패키지라면 grunt는 프로젝트의 하나의 모듈로 설치하는 것입니다. 실제로 grunt를 설치해야 비로서 프로젝트에 grunt를 사용할 수 있게 됩니다.

로컬 프로젝트에 설치하는 것이기 때문에 -g옵션은 없습니다.
--save-dev옵션은 package.json에 기록을 하되 devDependencies 항목에 기록을 하라는 옵션입니다.
npm install grunt --save-dev

Grunt로 사용할 다양한 패키지 설치

Grunt까지 설치를 하면 기본적으로 grunt를 사용할 준비가 된 상태입니다. 다만 그것만 가지고는 크게 할 수 있는 일이 없습니다. 그 Grunt가 명령을 내릴 다양한 패키지들의 설치가 필요합니다. 참고로 Grunt에서는 패키지플러그인이라고 부릅니다.

예를 들면 작성된 프로젝트의 javascript 소스가 문법에 맞게 잘 작성이 되었는지 검증 해 주는 jslint패키지(플러그인)도 있어야 하고 여러개로 분리된 javascript파일을 하나로 합쳐주는 concat도 있어야 하고 CSSSCSS로 개발했다면 이것도 CSS로 변환을 해주는 패키지(플러그인)도 있어야 합니다. 그런 패키지(플러그인)들은 프로젝트의 성향에 따라 다양하기 때문에 본인이 원하는 것을 골라서 설치하고 사용해야 합니다. 이러한 패키지(플러그인) 설치는 npmbower으로 설치를 하면 됩니다.

npm install grunt-contrib-jshint --save-dev

Grunt에서 사용하는 패키지(플러그인) 리스트는 Grunt사이트의 플러그인 메뉴에서 순위별로 제공을 하고 있습니다. 꼭 Grunt사이트의 플러그인 메뉴에 나온 것 들만 적용이 가능한것은 아니고 NPM사이트에서 제공하고 있는 패키지들도 설치가 가능 합니다.

다음 포스팅에는 Gruntfile.js의 구조와 작성법 그리고 유용한 패키지 등을 소개하도록 하겠습니다.

댓글

  1. npm WARN deprecated [email protected]: https://github.com/lydell/resolve-url#deprecated
    npm WARN deprecated [email protected]: Please see https://github.com/lydell/urix#deprecated
    C:\Users\파프리카\AppData\Roaming\npm\grunt -> C:\Users\파프리카\AppData\Roaming\npm\node_modules\grunt-cli\bin\grunt
    + [email protected]
    updated 1 package in 15.688s
    믕? 왜이래요?

    답글삭제
  2. 작성자가 댓글을 삭제했습니다.

    답글삭제

댓글 쓰기

이 블로그의 인기 게시물

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캘린더(달력)에 대한민국 휴일 표시하기

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