grunt入门

1. grunt是什么

一个可以运行 各种处理前端繁琐操作(压缩文件,删注释,测试等等)的插件 的平台。
所谓的自动化,就是插件帮你处理了各种繁琐的操作。而grunt的作用就是作为主管分配任务给插件,实现自动处理。

2. 如何使用

  1. 安装nodejs,与npm,必须的
  2. 安装grunt命令行到系统,从而可以在任何位置使用grunt

$ npm install grunt-cli -g //-g 的意思是全局

  1. 配置package.json 文件与 gruntfile.js 文件,以下以一个demo作为例子,新建文件夹内容如下:



    其中dest是处理完的文件,node_modules是库,src是源码,test是测试

  1. package.json是npm的库清单,写上要导入什么库,之后在所在目录输入下面的命令就可以自动导入

$ npm install

package.json也可以通过以下命令生成。

$ npm init

package.json的文件内容是大致是这样

{
    "name": "project-name",
    "version": "1.0.0",
    "description": "...",
    "main": "index.js",
    "keywords": [
      "flux",
      "react"
      ],
    "repository": "github_username/repository_name",
    "author": "your name",
    "license": "MIT",
    "devDependencies": {   
        "grunt": "^0.4.5",
        "grunt-contrib-concat": "^1.0.0",
        "grunt-contrib-connect": "^1.0.1",
        "grunt-contrib-cssmin": "^1.0.1",
        "grunt-contrib-htmlmin": "^1.2.0",
        "grunt-contrib-jshint": "^1.0.0",
        "grunt-contrib-qunit": "^1.1.0",
        "grunt-contrib-uglify": "^1.0.1",
        "grunt-contrib-watch": "^1.0.0",
        "jshint": "^2.9.1",
        "uglify": "^0.1.5",
        "watch": "^0.17.1"
      }
}

另外库也可以一个一个导入, 加了--save-dev可以自动写入到package.json文件中

$ npm install grunt-contrib-uglify --save-dev

  1. gruntfile.js是配置要执行的任务,文件内容大致如下
module.exports = function(grunt) {
    grunt.initConfig({
        //载入npm的库清单,必须
        pkg: grunt.file.readJSON("package.json"),
        
         //以下是插件的具体配置,各种插件的配置可参考官网,下面是一些例子
        //concat,合并文件
        concat:{
            options:{separator: ";"},   //合并的分隔符
            dist:{
                src:['src/*.js'],    //要合并的文件
                dest:'dest/<%= pkg.name %>.js'  //合成后的文件
            }
        },

        //minify js  压缩JS
        uglify:{
            options:{
                banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> */' 
            },  //banner 就是在压缩后的文件开头生成一个标签,这里是名字+日期
            dist:{
                src:["<%= concat.dist.dest %>"],  //表示要压缩concat之后的文件
                dest:"dest/<%= pkg.name %>.min.js"  //压缩后的文件
            }
        },

        //单元测试的工具
        qunit:{
            files:["test/*.html"]
        },
        //js的语法检查
        jshint:{
            files:['Gruntfile.js', 'src/*.js', 'test/*.js'],
        },
        //实现监控的工具,开启后每次改动文件都会执行里面定义的任务
        watch:{
            files:['<%= jshint.files %>', '<%= qunit.files %>'],
            tasks:['jshint', 'qunit']
        }
    });

    //载入库,必须的 
    grunt.loadNpmTasks('grunt-contrib-uglify');
    grunt.loadNpmTasks('grunt-contrib-concat');
    grunt.loadNpmTasks('grunt-contrib-watch');
    grunt.loadNpmTasks('grunt-contrib-jshint');
    grunt.loadNpmTasks('grunt-contrib-qunit');

    // 默认任务,命令行输入'grunt'运行,分先后顺序
    grunt.registerTask('default', ['concat' ,'uglify']);

   // 自定义任务, 命令行输入 'grunt test' 运行,test就是自定义的名字
    grunt.registerTask('test', ['jshint', 'qunit', 'watch']);
};

配置完之后就可以在命令行输入 grunt 来运行了

更多查看grunt官网

3. 总结

其实就是写两个文件package.json, gruntfile.js

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,319评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,801评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,567评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,156评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,019评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,090评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,500评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,192评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,474评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,566评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,338评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,212评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,572评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,890评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,169评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,478评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,661评论 2 335

推荐阅读更多精彩内容

  • Grunt入门(一) 什么是grunt Grunt就和photoshop里面的插件一样,它能够帮我们自动完成一些反...
    wheato阅读 2,207评论 0 9
  • 快速入门 Grunt和 Grunt 插件是通过 npm 安装并管理的,npm是 Node.js 的包管理器。Gru...
  • grunt是一个优秀的前端的自动化生产工具,最开始作者一直不用这类工具,感觉麻烦,但是当后面项目大一些后开始尝试使...
    PengL阅读 774评论 3 8
  • Grunt入门(二) 上一篇文章里,简单的讲解了grunt的使用方法。上一篇文章最后的问题,是不是每一个项目的gr...
    wheato阅读 1,544评论 0 3
  • 同事送了我两个芒果,还未熟透,香气新鲜而馥郁,如同少女般青春活泼。我把它放在办公桌上,等它成熟。每天早上来上班时,...
    蘭心阅读 276评论 2 0