首页 > 代码库 > 自动构建工具Grunt

自动构建工具Grunt

摘要:

  大部分项目在部署之前都需要做的就是js、css文件的压缩、合并,以及一些文件的错误检查,甚至是将LESS文件转换成css文件,coffeescript文件转化成js文件等等。但是项目开发是分迭代的,没开发完一次,上面的工作要重新做一遍。那有什么工具能帮助我们来做这些重复的工作呢?Grunt就是其中一个非常好用的工具。下面就来学习一下Grunt。

安装:

  Grunt是基于node.js,所以你先安装node.js,安装完之后,只需要执行下面的命令就可以安装Grunt

npm install -g grunt-cli

参数g表示全局安装,grunt-cli表示安装的是grunt的命令行界面。

  安装完成之后,他会把Grunt配置到你的系统路径,允许其从任何目录下运行。安装完之后并不能执行操作,因为Grunt是基于模块机构,所以必须安装模块。模块是局部的,是根据项目需求来安装的。在项目的随便一个目录下(最好是根目录,也可以随便创建个目录)新建一个文件---package.json(也可以通过node init来创建),内容如下:

{    "name": "",            // 项目名称    "version": "",         // 项目版本    "private": true,       // 项目是否私有    "description": "",     //  项目描述    "main": "",            // 项目主要文件    "dependencies": {},    // 项目依赖的模块    "devDependencies": {   // 项目开发阶段依赖的模块        "grunt": "0.x.x",  // grunt模块为最新的0.x.x版        "grunt-contrib-clean": "~0.5.0", // clean插件不低于0.5.0        "grunt-contrib-copy": "~0.5.0",        "grunt-contrib-less": "~0.11.0",        "grunt-contrib-uglify": "~0.4.0",        "grunt-contrib-watch": "~0.6.1",        "grunt-contrib-concat": "*"    },    "keywords": [],   // 项目关键字    "author": {       // 作者        "name": "",        "age": ""    },    "contributors": [],  // 贡献者     "license": ""        // 版权}

 

 

然后在当前目录下,通过命令终端运行npm install,这时你会发现多出一个node_modules文件夹,里面就是我们安装的模块。

配置:

  Grunt和模块都已经安装完成了,下面需要做的就是创建一个配置文件,来告诉Grunt需要去哪里,然后做什么等等。在上面的目录下新建一个文件Gruntfile.js(注意大小写),内容如下:

module.exports = function(grunt) {    ‘use strict‘;  // 配置Grunt各种模块的参数  grunt.initConfig({    clean:  {      oldMinFiles: [],      afterUglify: []    },    jslint: {      command: "",      options: ""    },    concat: {    },    uglify: {    },    watch:  {    },    copy: {    },    less: {    }  });  // 从node_modules目录加载模块文件  grunt.loadNpmTasks(‘grunt-contrib-copy‘);  grunt.loadNpmTasks(‘grunt-contrib-clean‘);  grunt.loadNpmTasks(‘grunt-cmd-concat‘);  grunt.loadNpmTasks(‘grunt-contrib-uglify‘);  grunt.loadNpmTasks(‘grunt-contrib-less‘);  grunt.loadNpmTasks(‘grunt-contrib-watch‘);  // 定义任务  grunt.registerTask(‘default‘, [‘jsLint‘, ‘concat‘, ‘uglify‘]);  grunt.registerTask(‘check‘, [‘jslint‘]);};

 

 

只需要在当前目录执行命令

合并文件:

grunt concat

代码检查:

grunt check 

 

 后期将介绍grunt的每一个模块。

附录:

 

grunt.initConfig

配置各模块的参数,每项对应一个同名模块。

grunt.loadNpmTasks

加载所需的模块。

grunt.registerTask

定义具体的任务。第一个参数为任务名,第二个参数是一个数组,表示该任务需要依次使用的模块。default是默认任务,即直接输入grunt命令,后面不跟任何参数,这时所调用的模块为default对应的任务。

 

 

  

 

自动构建工具Grunt