项目目录,js源文件

gruntest

Gruntfile.js

package.json

-- js

ext

community_plugin.js

glogin_frm_cover.js

iLogin.js

kkpv.js

lnk_plugin.js

md5.js

storyleak_plugin.js

tabSwitch.js

-- 5.2

js

download_main.js

mp4

js

kankan_commercial_mp4.js

kankan_page_mp4.js

kkc.js

kkcs.js

我用grunt简单的完成以下任务,

1.  js/ext/(community_plugin.js、iLogin.js、lnk_plugin.js、tabSwitch.js)压缩到js/*-min.js ,js/ext/(glogin_frm_cover.js、kkpv.js、md5.js、storyleak_plugin.js) 压缩合并到js/exm-min.js

2.  5.2/js/download_main.js压缩到5.2/js/download_main-min.js

3.  5.2/mp4/js/*.js压缩到5.2/mp4/js/*-min.js

任务配置文件Gruntfile.js语法

grunt.initConfig({
     js_exm_dir:{                                  //全局变量、自定义
        src:['js/ext/glogin_frm_cover.js','js/ext/kkpv.js','js/ext/md5.js','js/ext/storyleak_plugin.js'],
        dest:'js/exm-min.js'
     },

concat: {                       //任务concat
      options: {                    
         //任务配置
      },
      js_exm: {                    //子任务,自定义
           options和文件 ,子任务的option会覆盖任务option
      }
    }  
  });

1)<%=  %>读取变量值,最外层要有''包围!

2)可直接在子任务中配置文件

1.  concat: {

js_exm: {                    
         src:['src/b1.js','src/b2.js'],

dest:'dest/a1.js'
      }
    }

2.jshint:{                          //只有src可以采用此方式

with_overrides:['js/**/*.js'],

}

3.jshint:{                       //只有src可以采用此方式

with_overrides:'js/**/*.js',

}

3)另外子任务属性files有三种方式配置文件

1.concat: {

js_exm:{

files:{

'dest/a1.js':['src/b1.js','src/b2.js'],

'dest/a1.js':['src/c1.js','src/c2.js']

}

}

}

2.concat: {

js_exm:{

files:[

{dest:'dest/a1.js',src:['src/b1.js','src/b2.js']},

{dest: 'dest/a1.js',src:['src/c1.js','src/c2.js']}

]

}

}

3.jshint:{

with_overrides: {

files: {src: ['js/**/*.js']}           
       }

}

除了dest、src还有其他属性filter、nonull、dot、matchBase、expand。

源文件是多个文件时对文件列表进行平行展开即:['src/a.js','src/b.js','src/c.js']与[['src/a.js','src/b.js'],'src/c.js']是等效的。

另外有几种路径短配符*(匹配多个字符除/)、?(匹配单个字符除/)、**(匹配多个字符)、{}(用,隔开的or语句)、!(表示不匹配此路径)

下面介绍几种任务模块

1)文件合并

首先安装插件,在任务目录下 npm install grunt-contrib-concat --save-dev

concat: {

options: {                 
        separator: ';' ,
        banner: '/*! <%= grunt.template.today("dd-mm-yyyy") %> */\n'
      },      
      js_exm:{                                    
         dest:'<%= js_exm_dir.dest %>',src:'<%= js_exm_dir.src %>'      
      }
 },

2)文件压缩

首先安装插件,在任务目录下 npm install grunt-contrib-uglify --save-dev

uglify: {
      options: {
        banner: '/*! <%= pkg.name %> <%= grunt.template.today("dd-mm-yyyy") %> */\n'
      },
      js_exm_min: {
        files: {
          'js/exm.min.js': ['<%= concat.js_exm.dest %>']
        }
      }
}

3)代码优化

首先安装插件,在任务目录下 npm install grunt-contrib-jshint --save-dev

最后要注册插件

grunt.loadNpmTasks('grunt-contrib-uglify');
  grunt.loadNpmTasks('grunt-contrib-jshint');
  grunt.loadNpmTasks('grunt-contrib-qunit');
  grunt.loadNpmTasks('grunt-contrib-watch');
  grunt.loadNpmTasks('grunt-contrib-concat');

及注册任务

grunt.registerTask(taskname, [description,],tasklist)

如: grunt.registerTask('build', ['concat','uglify','jshint']);

另外可以注册任务的子任务只选择子任务运行如: grunt.registerTask('build-exm', ['concat:js-exm','uglify','jshint:with_overrides']);

运行命令为

可以利用grunt-api自定义任务,比如定义一个压缩单个js的任务

grunt.registerTask('ug-js', ['uglify:js_min']);
  grunt.registerTask('ug-single','uglify single js',function(src,dest){   
     grunt.config('tmpsrc',src);
     grunt.config('tmpdest',dest);
     grunt.task.run('ug-js');    
  });

uglify: {    
       js_min:{
        files:{'<%= tmpdest %>':'<%= tmpsrc %>'}
       }
  },

运行命令为

传入的参数不能有''。

还有一种从命令行传入参数进而定义一个压缩单个js的方式为:

var src = grunt.option('src');
  var dest = grunt.option('dest');
  grunt.config('tmpsrc',src);
  grunt.config('tmpdest',dest);

运行命令为

传入的参数不能有''。

Gruntfile.js代码如下:

 module.exports = function(grunt) {

   grunt.initConfig({
pkg:grunt.file.readJSON('package.json'),
js_exm_dir:{ //全局变量、自定义
src:['js/ext/glogin_frm_cover.js','js/ext/kkpv.js','js/ext/md5.js','js/ext/storyleak_plugin.js'],
dest:'js/exm.js'
},
concat: { //任务concat
options: { //配置
separator: ';' ,
banner: '/*! <%= grunt.template.today("dd-mm-yyyy") %> */\n'
},
js_exm:{ //子任务js_exm options和文件 ,子任务的option会覆盖任务concat全局option
dest:'<%= js_exm_dir.dest %>',src:'<%= js_exm_dir.src %>'
}
},
uglify: {
options: {
banner: '/*! <%= pkg.name %> <%= grunt.template.today("dd-mm-yyyy") %> */\n'
},
js_exm_min: {
files: {
'js/exm-min.js': ['<%= concat.js_exm.dest %>']
}
},
js_min_test:{
files:[
{dest:'js/community_plugin.js',src:'js/ext/community_plugin.js'},
{dest:'js/iLogin.js',src:'js/ext/iLogin.js'},
{dest:'js/lnk_plugin.js',src:'js/ext/lnk_plugin.js'},
{dest:'js/tabSwitch.js',src:'js/ext/tabSwitch.js'}]
},
js_min:{
files:{'<%= tmpdest %>':'<%= tmpsrc %>'}
}
},
qunit: {
files: ['test/**/*.html']
},
jshint: {
beforeconcat: ['Gruntfile.js'],
options: {
// options here to override JSHint defaults
"-W099":true,
"-W100":true,
globals: {
//module: true
}
},
with_overrides: {
options: {
"-W002":true,
"-W004":true,
"-W009":true,
"-W027":true,
"-W030":true,
"-W032":true,
"-W033":true,
"-W038":true,
"-W041":true,
"-W044":true,
"-W049":true,
"-W051":true,
"-W053":true,
"-W057":true,
"-W058":true,
"-W060":true,
"-W061":true,
"-W065":true,
"-W069":true,
"-W075":true,
"-W082":true,
"-W083":true,
"-W084":true,
"-W088":true,
"-W107":true,
"-W120":true,
ignores:['Gruntfile.js','js/exm-min.js'],
},
files: [
{src: ['js/**/*.js']},{src:['5.2/**/*.js']}
],
}
},
watch: {
files: ['<%= jshint.with_overrides.files %>'],
tasks: ['jshint', 'qunit']
}
}); grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-qunit');
grunt.loadNpmTasks('grunt-contrib-watch');
grunt.loadNpmTasks('grunt-contrib-concat'); grunt.registerTask('build-exm', ['concat:js_exm','uglify:js_exm_min']);
grunt.registerTask('ug-js', ['uglify:js_min']);
grunt.registerTask('ug-single','uglify single js',function(src,dest){
grunt.config('tmpsrc',src);
grunt.config('tmpdest',dest);
grunt.task.run('ug-js');
});
var src = grunt.option('src');
var dest = grunt.option('dest');
grunt.config('tmpsrc',src);
grunt.config('tmpdest',dest); }

package.json代码如下:

 {
"family": "test",
"version": "0.0.1",
"name": "gruntTest",
"spm": {
"alias": {
"jquery": "gallery/jquery/1.8.2/jquery",
"dialog": "dist/styles/component/dialog/src/dialog"
}
},
"devDependencies": {
"grunt": "~0.4.1",
"grunt-contrib-concat": "~0.3.0",
"grunt-contrib-uglify": "~0.2.4",
"grunt-contrib-jshint": "~0.6.4",
"grunt-contrib-qunit": "~0.3.0",
"grunt-contrib-watch": "~0.5.3"
}
}

grunt轻松入门的更多相关文章

  1. 前端自动化grunt轻松入门

    如果你还不了解grunt,或者只是听过它的名字而没有去研究过它,那么这篇入门级的文章就是为你写的,相信看完你就会爱上grunt! grunt是什么? grunt是一个非常好的自动化工具,你只管code ...

  2. Groovy轻松入门——通过与Java的比较,迅速掌握Groovy (更新于2008.10.18)

    摘自: http://www.blogjava.net/BlueSUN/archive/2007/03/10/103014.html Groovy轻松入门--通过与Java的比较,迅速掌握Groovy ...

  3. Groovy轻松入门——搭建Groovy开发环境

    摘自: http://www.blogjava.net/BlueSUN/archive/2007/03/17/104391.html Groovy轻松入门--搭建Groovy开发环境 多日来,我发表了 ...

  4. C++ STL编程轻松入门基础

    C++ STL编程轻松入门基础 1 初识STL:解答一些疑问 1.1 一个最关心的问题:什么是STL 1.2 追根溯源:STL的历史 1.3 千丝万缕的联系 1.4 STL的不同实现版本 2 牛刀小试 ...

  5. Swift轻松入门——基本语法介绍和详细地Demo讲解(利用WebView打开百度、新浪等网页)

    转载请务必注明出处(all copyright reserved by iOSGeek) 本文主要分为两个部分,第一部分介绍Swift的基本语法,第二部分讲解一个利用WebView来打开百度.sina ...

  6. Grunt使用入门

    Grunt使用入门 (by vczero) 一.前言 项目中一直在使用Grunt,只是对Grunt的基本使用,却未系统的总结过.为什么要构建工具?一句话:自动化.对于需要反复重复的任务,例如压缩(mi ...

  7. JavaScript面向对象轻松入门之封装(demo by ES5、ES6、TypeScript)

    本章默认大家已经看过作者的前一篇文章 <JavaScript面向对象轻松入门之抽象> 为什么要封装? 封装(Encapsulation)就是把对象的内部属性和方法隐藏起来,外部代码访问该对 ...

  8. asp.net core轻松入门之MVC中Options读取配置文件

    接上一篇中讲到利用Bind方法读取配置文件 ASP.NET Core轻松入门Bind读取配置文件到C#实例 那么在这篇文章中,我将在上一篇文章的基础上,利用Options方法读取配置文件 首先注册MV ...

  9. AngularJs轻松入门

    AngularJs轻松入门系列博文:http://blog.csdn.net/column/details/angular.html AngularJs轻松入门(一)创建第一个应用 AngularJs ...

随机推荐

  1. Socket协议

    Socket协议的形象描述 socket的英文原义是"孔"或"插座".在这里作为4BDS UNIX的进程通信机制,取后一种意思.socket非常类似于电话插座. ...

  2. Fundebug上线Node.js错误监控啦

    作为全栈JavaScript错误实时监测平台,Fundebug的Node.js实时错误监测服务上线啦,我们能够帮助开发者及时,高效地发现并且解决Node.js错误,从而提高开发效率,并提升用户体验. ...

  3. MVC插件实现

    本人第一篇随笔,在园子里逛了这么久,今天也记录一篇自己的劳动成果,也是给自己以后留个记录. 最近领导让我搞一下插件化,就是实现多个web工程通过配置文件进行组装.之前由于做过一个简单的算是有点经验,当 ...

  4. ASP.NET Core:CMD命令行+记事本 创建Console程序和Web Application

    今天看了Scott关于ASP.NET Core的介绍视频,发现用命令行一步一步新建项目.添加Package.Restore.Build.Run 执行的实现方式,更让容易让我们了解.NET Core的运 ...

  5. maven修改远程和本地仓库地址

    简介:我们用maven的时候,maven自带的远程中央仓库经常会很慢,还有默认本地仓库是在c盘C:\Users\你的电脑用户账号\.m2\repository, 对于有强迫症的人,总是看的不爽,下面介 ...

  6. python之字符串

    字符串与文本操作 字符串: Python 2和Python 3最大的差别就在于字符串 Python 2中字符串是byte的有序序列 Python 3中字符串是unicode的有序序列 字符串是不可变的 ...

  7. smokeping安装部署最佳实践

    1.1安装smokeping [root@linux-node2 ~]# cat /etc/redhat-release              #查看服务器信息 CentOS release 6. ...

  8. Flash加载ini文件!

    这个帖子里有解决方案: http://bbs.9ria.com/thread-405128-1-1.html

  9. 【iOS】7.4 定位服务->3.3 地图框架MapKit 功能3:3D视图

    本文并非最终版本,如果想要关注更新或更正的内容请关注文集,联系方式详见文末,如有疏忽和遗漏,欢迎指正. 本文相关目录: ================== 所属文集:[iOS]07 设备工具 === ...

  10. JS弹出框

    一.JS三种最常见的对话框 1.alert()警告框      alert是警告框,只有一个按钮"确定"无返回值,警告框经常用于确保用户可以得到某些信息.当警告框出现后,用户需要点 ...