任务自动管理工具,详解(需要翻墙)
快捷导航:
安装
Grunt 基于 node.js ,安装之前请先安装node.js / npm
grunt-cli 表示安装grunt的命令行界面
npm install grunt-cli -g
grunt 使用模块结构,除了命令行界面意外,还根据需要安装相应的模块。 (不同项目可能需要同一个模块的不同版本,因而建议分开安装)
手动创建package.json
- 在项目根目录下,创建一个文本文件package.json,指定当前项目所需要的模块。
{ "name": "my-project-name", "version": "0.1.0", "devDependencies": { "grunt": "0.4.*", "grunt-contrib-clean": "~0.5.0", "grunt-contrib-coffee": "~0.10.1", "grunt-contrib-less": "~0.9.0", "grunt-contrib-yuidoc": "~0.5.0" } } - 在项目根目录下运行下面的命令,这些插件就会被自动安装在node_modules子目录中。
npm install
自动生成package.json
使用以下命令,按屏幕提示回到所需模块的名称和版本即可
npm init
已有package.json 文件不包括grunt模块。
可以在直接安装grunt模块的时候,加上--save-dev参数,该模块就会自动被加入package.json文件。
npm install <module> --save-dev
比如,对应上面package.json文件指定的模块,需要运行以下npm命令。
npm install grunt --save-dev npm install grunt-contrib-clean --save-dev npm install grunt-contrib-coffee --save-dev npm install grunt-contrib-less --save-dev npm install grunt-contrib-yuidoc --save-dev
命令脚本文件
根目录下,新建gruntfile.js || gruntfile.coffee 脚本文件,他是grunt的配置文件
gruntfile.js 就是一般的 node.js 模块的写法
JS版
module.exports = function(grunt) {
// 配置Grunt各种模块的参数
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
jshint: { /* jshint的参数 */ },
concat: { /* concat的参数 */ },
uglify: { /* uglify的参数 */ },
watch: { /* watch的参数 */ }
});
// 从node_modules目录加载模块文件
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-contrib-watch');
// 每行registerTask定义一个任务
grunt.registerTask('default', ['jshint', 'concat', 'uglify']);
grunt.registerTask('check', ['jshint']);
};CoffeeScript 版
module.exports = (grunt)->
# 配置Grunt各种模块的参数
grunt.initConfig
pkg: grunt.file.readJSON('package.json')
#从node_modules目录加载模块文件
grunt.loadNpmTasks 'grunt-contrib-clean'
grunt.loadNpmTasks 'grunt-contrib-coffee'
grunt.loadNpmTasks 'grunt-contrib-less'
grunt.loadNpmTasks 'grunt-contrib-yuidoc'
grunt.loadNpmTasks 'grunt-contrib-copy'
grunt.registerTask 'build', [
'clean:build',
'coffee',
'less:build',
]
grunt.registerTask 'dist', [ 'build', 'clean:dist', 'copy:build']- grunt.initConfig: 定义各种模块的参数,每一个成员项对应一个同名模块。
- grunt.loadNpmTasks: 加载完成任务所需的模块。
- grunt.registerTask: 定义具体的任务。 第一个参数为任务名。 第二个参数是一个数组,表示该任务需要依次使用的模块。 default任务名表示,如果直接输入grunt命令,后面不跟任何参数,这时所调用的模块(该例为jshint,concat和uglify)
执行
命令行执行某个模块
grunt jshint
命令行执行某个任务, 只键入grunt 则执行默认default任务
grunt check
grunt常用方法
grunt.loadNpmTasks 载入文件模块
每加载一个模块都需要引入一个 grunt.loadNpmTasks方法,如果加载模块过多,会非常冗长,而且凡是加载模块同时,也会载入到package.json 文件中,如果使用npm命令卸载模块以后,模块也会从package.json中删除。而gruntfile文件则需要手动删除,容易造成运行错误。
解决方案:
安装load-grunt-tasks模块,在gruntfile.js文件中用下面的语句替代所有的grunt.loadNpmTasks
require('load-grunt-tasks')(grunt);
这条语句的作用是自动分析package.json文件,加载所找到的grunt模块。
grunt.initConfig 用于模块配置
grunt.initConfig({
cssmin: {
minify: {
expand: true,
cwd: 'css/',
src: ['*.css', '!*.min.css'],
dest: 'css/',
ext: '.min.css'
},
combine: {
files: {
'css/out.min.css': ['css/part1.min.css', 'css/part2.min.css']
}
}
}
});接收一个对象作为参数,该对象的成员与使用的同名模块一一对应。
Eg:我们要配置的是cssmin模块,所以initConfig里面有一个cssmin成员(属性)
每一个属性指向一个对象,该对象有包含了多个成员。一些是系统设定的成员(options),另一些是自定义的成员(被称为目标target)。一个模块可以有多个target。
例子中的minify用于压缩css,另一combine,用于多个css合并一个文件
每一个target的具体设置需要参模板的文档。
grunt.registerTask 定义如何调用具体任务
grunt.registerTask('default', ['cssmin:minify','cssmin:combine'])"default" 任务表示如果不提供参数,直接输入grunt命令,则先运行“cssmin:minify”,后运行“cssmin:combine”,即先压缩再合并。
grunt # 默认情况下,先压缩后合并
如果只执行压缩,或者只执行合并,则需要在grunt命令后面指明“模块名:目标名”。
grunt cssmin:minify # 只压缩不合并 grunt css:combine # 只合并不压缩
如果不指明目标,只是指明模块,就表示将所有目标依次运行一遍。
grunt cssmin
常用模块设置
} grunt-contrib-clean:删除文件。 } grunt-contrib-compass:使用compass编译sass文件。 } grunt-contrib-concat:合并文件。 } grunt-contrib-copy:复制文件。 } grunt-contrib-cssmin:压缩以及合并CSS文件。 } grunt-contrib-imagemin:图像压缩模块。 } grunt-contrib-jshint:检查JavaScript语法。 } grunt-contrib-uglify:压缩以及合并JavaScript文件。 } grunt-contrib-watch:监视文件变动,做出相应动作。
** 注:前缀 grunt-contrib- 表示该模块由grunt开发团队维护 grunt- 表示由第三方开发者维护
- grunt-contrib-jshint 检查语法错误,比如分号的使用是否错误,有无括号等。
jshint: {
options: {
eqeqeq: true, // 是否严格检查
trailing: true // 结尾不得有多有空格
},
files: ['Gruntfile.js', 'lib/**/*.js'] // 检查目标
},- grunt-contrib-concat 用来合并同类文件,css和js
concat: {
js: {
src: ['lib/module1.js', 'lib/module2.js'],
dest: 'dist/script.js' // 合并js文件
},
css: {
src: ['style/base.css', 'style/theme.css'],
dest: 'dist/screen.css' // 合并css文件
}
},- grunt-contrib-uglify 压缩代码,减小文件体积
uglify: {
// 指定压缩后文件的头文件
options: {
banner: bannerContent,
sourceMapRoot: '../',
sourceMap: 'distrib/'+name+'.min.js.map',
sourceMapUrl: name+'.min.js.map'
},
// target目标制定输入和输出文件
target : {
expand: true,
cwd: 'js/origin',
src : '*.js',
dest : 'js/'
}
},- grunt-contrib-copy
copy: {
main: {
expand: true,
cwd: 'src/',
src: '**',
dest: 'dest/',
flatten: true,
filter: 'isFile',
},
},