module.exports = function(grunt)
{
  grunt.initConfig({
        pkg: grunt.file.readJSON('package.json'),
        clean:
        {
            Task_001: //任务一
            {
                expand:true,
                src:['build/**']
            }
        },
        uglify: //js代码压缩
        {
            options:
            {
                mangle: false, //不混淆变量名
                //stripBanners:'all',
                //banner: '/*! <%= pkg.name %> <%= grunt.template.today("dd-mm-yyyy") %> */\n', //添加header
                //footer:'\n/*! <%= pkg.name %> 最后修改于: <%= grunt.template.today("yyyy-mm-dd") %> */'//添加footer
            },
            Task_001: //任务一
            {
                files:
                [
                    {
                        expand:true, //如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:"src/js", //src目录下
                        src:"**/*.js", //所有的文件夹中的js文件
                        dest:"build/js" //放在build文件夹中的js文件夹中
                    },
                    {
                        expand:true, //如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:"src/js", //src目录下
                        src:"*.js", //所有的js文件
                        dest:"build/js" //放在build文件夹中的js文件夹中
                    }
                ]
            },
            Task_002:
            {
                files:
                [
                    {
                        expand:true, //如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:"src/js", //src目录下
                        src:"My_Js/*.js", //所有的文件夹中的js文件
                        dest:"build/js" //放在build文件夹中的js文件夹中
                    },
                ]
            }
        },
        cssmin:
        {
            options:
            {
                report:'gzip'
            },
            Task_001: //任务一
            {
                files:
                [
                    {
                        expand:true, //如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:'src/css', //css目录下
                        src:"**/*.css", //所有的文件夹中的css文件
                        dest:"build/css" //放在build文件夹中的css文件夹中
                    },
                    {
                        expand:true, //如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:'src/css', //css目录下
                        src:"*.css", //所有的css文件
                        dest:"build/css" //放在build文件夹中的css文件夹中
                    }
                ]
            },
            Task_002: //任务二
            {
                files:
                [
                    {
                        expand:true, //如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:'src/css', //css目录下
                        src:"My_css/*.css", //所有的文件夹中的css文件
                        dest:"build/css" //放在build文件夹中的css文件夹中
                    }
                ]
            },
        },
        imagemin:
        {
            Task_001: //任务一
            {
                options:
                {
                     optimizationLevel:  //定义 PNG 图片优化水平
                },
                files:
                [
                    {
                        expand:true,//如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:'src/Images',//images目录下
                        src:'*.{png,jpg,jpeg,gif}',//所有的img文件
                        dest:'build/Images'//Images
                    },
                    {
                        expand:true,//如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:'src/Images',//images目录下
                        src:'**/*.{png,jpg,jpeg,gif}',//所有的img文件
                        dest:'build/Images'//Images
                    }
                ]
            }
        },
        htmlmin:
        {
             //https://www.npmjs.com/package/html-minifier
             options:
             {
                    removeComments: true,               //删除html注释
                    removeCommentsFromCDATA: true,      //删除带HTML注释脚本和样式
                    removeCDATASectionsFromCDATA:true,  //从脚本删除CDATA节和风格元素
                    collapseWhitespace:true,            //崩溃的空白,导致文本节点在文档树。
                    conservativeCollapse:true,            //总是省略空间必须使用与collapseWhitespace = true
                    collapseInlineTagWhitespace:true,    //之间不要留下任何空间显示:内联元素时崩溃。必须使用与collapseWhitespace = true
                    preserveLineBreaks:false,             //(false既开启超级压缩)总是省略换行之间的空白标签包含一个换行符。必须使用与collapseWhitespace = true
                    collapseBooleanAttributes:true,        //省略属性值从布尔属性
                    removeTagWhitespace:true,            //尽可能消除之间的空间属性。
                    removeAttributeQuotes:true,            //删除引号属性。
                    removeRedundantAttributes:true,        //删除属性值匹配时违约。
                    preventAttributesEscaping:true,        //防止逃跑的属性的值。
                    useShortDoctype:true,                //替换的doctype短(HTML5)doctype
                    removeEmptyAttributes:true,            //删除所有空格作属性值
                    removeScriptTypeAttributes:true,    //删除type = " text / javascript脚本标签。其他类型属性值剩下完好无损。
                    removeStyleLinkTypeAttributes:true, //删除类型= " text / css "从风格和链接标记。其他类型属性值剩下完好无损
                    removeOptionalTags:true,            //删除没有要求标签
                    //removeEmptyElements:true,            //删除所有元素空内容
                    keepClosingSlash:true,                //保持尾部的斜杠单元素
                    caseSensitive:true,                    //以区分大小写的方式处理属性(用于自定义HTML标记。)
                    minifyJS:true,                        //压缩Javascript脚本元素和事件属性(使用UglifyJS)
                    minifyCSS:true,                        //压缩CSS样式元素和风格属性(使用clean-css)
                    minifyURLs:true,                    //压缩url在不同属性(使用relateurl)
                    includeAutoGeneratedTags:true,        //插入标记生成的HTML解析器
                    quoteCharacter:true                    //类型的引用使用属性值(“或”)
            },
            Task_001: //任务一
            {
                files:
                [
                    {
                        expand:true,   //如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:"src", //app目录下
                        src:"**/*.html", //所有的文件夹中的html文件
                        dest:"build"//放在build文件夹中的html文件夹中
                    },
                    {
                        expand:true,   //如果设为true,就表示下面文件名的占位符(即*号)都要扩展成具体的文件名。
                        cwd:"src", //html目录下
                        src:"*.html", //所有的html文件
                        dest:"build"//放在build文件夹中的html文件夹中
                    }
                ]
            }
        },
        copy:  //将编译好的文件,复制到我的项目中
        {
            Task_001: //任务一
            {
                files:
                [
                    {
                        expand:true,
                        cwd:'build',
                        src:'**',
                        dest:'www'
                    }
                ]
            }
        },
        watch: //自动监听文件的保存并执行指定的任务
        {
            Task_001: //任务一
            {
                files:['src/js/*.js','src/css/*.css','src/*.html'],
                tasks:['uglify:Task_002','cssmin:Task_002','htmlmin'],
                options:{ spawn:false}
            }
        }
  });

  //#####告诉grunt我们将使用的插件
  grunt.loadNpmTasks('grunt-contrib-clean');     //js压缩
  grunt.loadNpmTasks('grunt-contrib-uglify');     //js压缩
  grunt.loadNpmTasks('grunt-contrib-cssmin');     //css压缩
  grunt.loadNpmTasks('grunt-contrib-imagemin'); //image压缩
  grunt.loadNpmTasks('grunt-contrib-htmlmin');  //html压缩
  grunt.loadNpmTasks('grunt-contrib-copy');     //Copy文件和目录
  grunt.loadNpmTasks('grunt-contrib-watch');         //监视文件

  //#####告诉grunt我们在终端输入grunt时需要做一些什么
  grunt.registerTask('default',['clean','uglify','cssmin','imagemin','htmlmin','copy','watch']);
};

Gruntfile.js的更多相关文章

  1. grunt使用watch和livereload的Gruntfile.js的配置

    周末在家看angularJS, 用grunt的livereload的自动刷新, 搞了大半天, 现在把配置贴出来, 免得以后忘记了, 只要按照配置一步步弄是没有问题的; 开始的准备的环境安装是: (1) ...

  2. Grunt 自动化部署之css、image、javascript、html压缩Gruntfile.js配置

    grunt.initConfig方法 用于模块配置,它接受一个对象作为参数.该对象的成员与使用的同名模块一一对应. 每个目标的具体设置,需要参考该模板的文档.就cssmin来讲,minify目标的参数 ...

  3. ☀【Grunt】package.json, Gruntfile.js, npm install, grunt

    npm install --registry http://registry.npm.taobao.org/ 切换源 Grunt.js 在前端项目中的实战http://beiyuu.com/grunt ...

  4. 使用grunt-init自动创建gruntfile.js和package.json文件

    使用grunt-init可以自动创建gruntfile.js和package.json文件.下面说一下过程: 1.全局安装grunt-init npm install -g grunt-init 2. ...

  5. Gruntfile.js模板

    module.exports = function(grunt) { // 配置项 var AppConfig = { name: 'app', //源文件目录 src: 'app/src', //生 ...

  6. Gruntfile.js文件配置项

    GRUNT安装与配置 Posted on 2016-08-19 18:13 听风吹来的种子 阅读(47) 评论(0) 编辑 收藏 安装 CLI npm install -g grunt-cli//全局 ...

  7. 编写可维护的 Gruntfile.js

    load-grunt-tasks 插件 首先介绍下 load-grunt-tasks 这个插件. 我们一般都会把所有用到的插件以及插件的配置写到 Gruntfile.js 里面,对于小项目来说这个文件 ...

  8. Grunt:GruntFile.js

    ylbtech-Grunt:GruntFile.js 1.返回顶部 1. module.exports = function (grunt) { grunt.initConfig({ useminPr ...

  9. 一路编程 -- Gruntfile.js

    <一路编程> Steven Foote 第四章构建工具 中的 Gruntfile.js 文件的 JSHint 部分,如果按照书中所写,run  grunt 的命令的时候会出错. 此处附上完 ...

  10. Javascript模块化开发2——Gruntfile.js详解

    一.grunt模块简介 grunt插件,是一种npm环境下的自动化工具.对于需要反复重复的任务,例如压缩.编译.单元测试.linting等,自动化工具可以减轻你的劳动,简化你的工作.grunt模块根据 ...

随机推荐

  1. background为圆角的表框,dp转Px,Px转dp

    圆角边框<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="ht ...

  2. java 汽车销售收入系统

     >>>>>>>>>>>>>>>>>>>> 语言:java 工具:eclipse ...

  3. 【JavaScript】变量定义提升、this指针指向、运算符优先级、原型、继承、全局变量污染、对象属性及原型属性优先级

    参考资料http://caibaojian.com/toutiao/5446 1.所有变量声明(var)或者声明函数都会被提升到当前函数顶部 关于函数表达式,js会将代码拆分为两行代码分别执行.这里需 ...

  4. Linux IO模型和网络编程模型

    术语概念描述: IO有内存IO.网络IO和磁盘IO三种,通常我们说的IO指的是后两者. 阻塞和非阻塞,是函数/方法的实现方式,即在数据就绪之前是立刻返回还是等待. 以文件IO为例,一个IO读过程是文件 ...

  5. js动画实现侧边栏分享

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  6. IE下Array.prototype.slice.call(params,0)

    i8 不支持 Array.prototype.slice.call(params,0) params可以是 HTMLCollection.类数组.string字符串

  7. #来自codeforces round 363

    具体情况是这样的:同样的程序,在我自己的电脑上跑出来是正确的结果,而提交到CF的评测机后对于相同的输入数据,结果居然不一样了!反复检查后未发现任何问题.目前怀疑可能与memset有关,因为在一步步修改 ...

  8. BZOJ4631 : 踩气球

    将所有盒子插入链表,每当一个盒子变空时,从链表里删去它. 查一下它的前驱后继$pre,nxt$,那么$[pre+1,nxt-1]$都是空的. 每次对于$[A,B]$这段都为空,对小朋友按$R$维护线段 ...

  9. [linux]crontab 命令执行问题

    在服务器上设置了一个R脚本的crontab任务,死活不执行.在网上搜了很久,终于解决了. 这里主要说一下crontab异常时,该如何排查. 假设cron命令为:* * * * Rscript /you ...

  10. gulp完全开发指南 => 快来换掉你的Grunt吧

    最近一直在构建Angular应用,通过bower管理前端包依赖,然后通过gulp和它配合.发现gulp相比于grunt真的很轻,现在我的项目中已经取代了grunt.这里把我的一些实践贴记录下来和大家分 ...