티스토리 뷰
Grunt란?
Grunt는 JavaScript 작업 자동화 도구이다. Java 진영의 Maven, Gradle과 같은 프로젝트 빌드 도구라고 생각하면 이해하기 쉽다. 최근 프론트엔드 영역의 개발 복잡성이 증가하면서 JavaScript 또한 빌드의 대상이 되고 있다. 이번 글에서는 Grunt를 이용하여 복수개의 JavaScript 소스 코드를 병합(Concat), 축약(Uglify)하는 방법을 소개하고자 한다.
Grunt 사용을 위한 준비사항
Grunt를 사용하려면 프로젝트 루트 디렉토리에 package.json
, Gruntfile.js
가 작성되어 있어야 한다. Java 진영의 Gradle과 build.gradle
의 관계를 생각하면 이해하기 쉽다.
콘솔에서 grunt
명령어를 사용하려면 NPM을 이용한 설치가 필요하다.
$ npm install -g grunt-cli
이제 프로젝트 루트에서 package.json
을 작성한다.
{
"name": "sample-app",
"version": "0.0.1",
"devDependencies": {
"grunt": "1.0.1",
"grunt-contrib-concat": "1.0.1",
"grunt-contrib-uglify": "2.0.0"
}
}
- 기본 종속성으로
grunt
를 추가한다. 또한, 이번 글에서 소개할grunt-contrib-concat
,grunt-contrib-uglify
를 추가한다.
NPM으로 앞서 정의한 package.json
대로 해당 모듈들을 설치한다. 작업이 완료되면 프로젝트 루트 디렉토리에 node_modules
디렉토리가 생성된다.
npm install
Gruntfile.js 작성
마지막 관문이다. 프로젝트 루트 디렉토리에 Gruntfile.js
을 아래와 같이 자동화할 작업을 작성한다.
module.exports = function(grunt) {
grunt.initConfig({
concat: {
build: {
files: {
'dist/app.js', ['src/main/javascript/app.js', 'src/main/javascript/app2.js']
}
}
},
uglify: {
build: {
files: {
'dist/app.min.js': ['dist/app.js']
}
}
}
});
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-uglify');
}
Grunt 작업 실행
앞서 정의한 작업을 아래와 같이 실행한다. 첫번째는 소스 코드를 병합(Concat)하는 명령어이다.
$ grunt concat
두번째는 소스 코드를 축약(Uglify)하는 명령어이다.
$ grunt uglify
참고 글
댓글
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- kotlin
- spring
- 알뜰폰
- 로드 바이크
- jstl
- Spring Boot
- jpa
- jsp
- Eclipse
- Spring MVC 3
- 태그를 입력해 주세요.
- JHipster
- maven
- 평속
- Docker
- node.js
- 구동계
- graylog
- bootstrap
- 로드바이크
- JavaScript
- 자전거
- CentOS
- chrome
- Tomcat
- DynamoDB
- Kendo UI Web Grid
- MySQL
- Kendo UI
- java
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함