grunt例子:https://github.com/Aquarius1993/gruntDemo
1、前提是已经有npm(可以通过安装nodejs实现)
2、 npm update -g npm 更新npm
3、安装 CLI  npm isntall -g grunt-cli
4、 编写GRuntfile.js
 
usemin:

Example: The following block(html文件里学院这样写)

<!-- build:js scripts/site.js -->',
<script src="foo.js"></script>',
<script src="bar.js"></script>',
<script src="baz.js"></script>',
<!-- endbuild -->'

  

is parsed as, and given to createConfig as:

var block = {
type: 'js',
dest: 'scripts/site.js',
src: [
'foo.js',
'bar.js',
'baz.js'
],
raw: [
' <!-- build:js scripts/site.js -->',
' <script src="foo.js"></script>',
' <script src="bar.js"></script>',
' <script src="baz.js"></script>',
' <!-- endbuild -->'
]
};

  

 
Gruntfile.js里写这个:

usemin: {
html: 'index.html',
options: {
blockReplacements: {
less: function (block) {
return '<link rel="stylesheet" href="' + block.dest + '">';
}
}
}
}

  

 
例子/*
* @Author: liheyao
* @Date:   2016-06-08 14:49:25
* @Last Modified by:   liheyao
* @Last Modified time: 2016-06-13 18:04:52
*/
 
module.exports = function(grunt) {
// Project configuration.
var timestamp=new Date().getTime();
grunt.initConfig({
clean: {
all: 'bulid/'
},
copy: {
image: {
files: [
{
expand: true,
cwd: 'src',
src: ['*.html'],
dest: 'bulid/'
},
{
expand: true,
cwd: 'src',
src: ['img/*.{png,jpg,jpeg,gif,ico}'],
dest: 'bulid/'
}
]
}
},
// 合并js
concat: {
options: {
separator: ';',
stripBanners: true
},
prod: {
files: [
{
src: ["src/js/test.js","src/js/test1.js"],
dest: "bulid/js/test-concat.js"
},
{
src: ["src/js/testtest1.js","src/js/testtest2.js","src/js/testtesttest3.js"],
dest: "bulid/js/testtest-concat.js"
}
]
}
},
// 压缩js
uglify: { dev:{ //名字随意
files: {
'bulid/js/test-concat.min.js':['<%= concat.prod.files[0].dest %>'],
'bulid/js/testtest-concat.min.js': ['<%= concat.prod.files[1].dest %>'],
'bulid/js/auto-focus.min.js': ["src/js/auto-focus.js"],
'bulid/js/index.min.js': ["src/js/index.js"],
'bulid/js/conditional.min.js': ["src/js/conditional.js"],
}
}
},
jshint: {//js验证
all: ['Gruntfile.js']
},
sass: {//默认不压缩 可通过style改变
dist: {
options: {
style: 'compressed'//style: nested 嵌套缩进的css代码。是默认值 expanded 没有缩进 扩展的css代码 compact 简洁格式的css代码 compressed 压缩后的css代码
},
files: [{
expand: true,
cwd: 'src/sass/',
src: ['*.scss','*.css'],
dest: 'bulid/css',
ext: '.css'
}]
}
},
htmlmin: {
options: {
removeComments: true,
removeCommentsFromCDATA: true,
collapseWhitespace: true,
collapseBooleanAttributes: true,
removeAttributeQuotes: true,
removeRedundantAttributes: true,
useShortDoctype: true,
removeEmptyAttributes: true,
removeOptionalTags: true
},
html: {
files: [{
expand: true,
cwd: 'bulid/',
src: ['*.html'],
dest: 'bulid/'
}]
}
},
imagemin: {
prod: {
options: {
optimizationLevel: 7,
pngquant: true
},
files: [
{
expand: true,
cwd: 'bulid/',
src: ['img/*.{png,jpg,jpeg,gif,webp,svg}'],
dest: 'bulid/'
}
]
}
},
// 处理html中css、js 引入合并问题
usemin: {
html: ['bulid/*.html'],
options: {
blockReplacements: {
js: function (block) {
return '<script type="text/javascript" src="' + block.dest + '?t=' + timestamp + '"></script>';
},
css: function (block) {
return '<link rel="stylesheet" type="text/css" href="' + block.dest + '?t=' + timestamp + '"/>';
}
}
}
},
watch: {
sass: {
files: ['src/sass/*.scss'],
tasks:'sass'
},
uglify:{
files: ['src/js/*.js'],
tasks: 'uglify'
},
htmlmin: {
files: ['src/*.html'],
tasks: 'htmlmin'
},
livereload: {
options: {
livereload: true
},
files:'bulid/**/*'
}
}
});
// 加载包含“uglify”任务的插件 grunt.loadNpmTasks('grunt-contrib-watch');
grunt.loadNpmTasks('grunt-contrib-htmlmin');
grunt.loadNpmTasks('grunt-contrib-imagemin');
grunt.loadNpmTasks('grunt-contrib-clean');
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-usemin');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-sass');
grunt.loadNpmTasks('grunt-contrib-copy');
// 默认被执行的任务列表
grunt.registerTask('default',['clean','copy','concat','uglify','jshint','sass','usemin','htmlmin','imagemin']);//
};

  

 
 

grunt使用的更多相关文章

  1. 初学seaJs模块化开发,利用grunt打包,减少http请求

    原文地址:初学seaJs模块化开发,利用grunt打包,减少http请求 未压缩合并的演示地址:demo2 学习seaJs的模块化开发,适合对seajs基础有所了解的同学看,目录结构 js — —di ...

  2. grunt配置任务

    这个指南解释了如何使用 Gruntfile 来为你的项目配置task.如果你还不知道 Gruntfile 是什么,请先阅读 快速入门 指南并看看这个Gruntfile 实例. Grunt配置 Grun ...

  3. 快速开发Grunt插件----压缩js模板

    前言 Grunt是一款前端构建工具,帮助我们自动化搭建前端工程.它可以实现自动对js.css.html文件的合并.压缩等一些列操作.Grunt有很多插件,每一款插件实现某个功能,你可以通过npm命名去 ...

  4. 是时候搁置Grunt,耍一耍gulp了

    也算是用了半年Grunt,几个月前也写过一篇它的入门文章(点此查看),不得不说它是前端项目的一个得力助手.不过技术工具跟语言一样日新月异,总会有更好用的新的东西把旧的拍死在沙滩上(当然Grunt肯定没 ...

  5. 应用Grunt自动化地优化你的项目前端

    在不久前我曾写了一篇 应用r.js来优化你的前端 的文章,为大家介绍了r.js这个实用工具,它可以很好地压缩.合并前端文件并打包整个项目.但是如果将r.js放到项目中,我们不得不顾及到一个问题——项目 ...

  6. Grunt(页面静态引入的文件地址的改变探究)-V2.0

    相关插件的引用: grunt-usemin  对页面的操作 grunt-contrib-cssmin  压缩css load-grunt-tasks 瘦身gruntfile grunt-rev给md5 ...

  7. Grunt基本使用-V1.0

    浅语:grunt中文网:http://www.gruntjs.net/ 第一步:Grunt 依赖 Node.js 所以在安装之前确保你安装了 Node.js.然后开始安装 Grunt. 实际上,安装的 ...

  8. nodejs、npm、grunt——名词解释

    最近着手开发一个新项目,打算从工程化的角度整理一套自己的前端开发.发布体系. grunt这些工具,之前别人用我也用,并没有认真想过它们的前世今生,正好趁着这个机会,我来理一理目前业界比较流行这些工具的 ...

  9. grunt自定义任务——合并压缩css和js

    npm文档:www.npmjs.com grunt基础教程:http://www.gruntjs.net/docs/getting-started/ http://www.w3cplus.com/to ...

  10. Grunt学习使用

    原文地址:Grunt学习使用必看 grunt简介神马的不多说,到处一大堆. 我只说说我已经实现了的代码. 按照官方的教程 相信已经配置好了,接下来说 package.json 和 Gruntfile. ...

随机推荐

  1. mysql对数据库的备份和还原

    在对mysql数据库的某个数据库进行备份时,使用 mysqldump命令来进行操作 mysqldump -u root -p db_database_name > /[your_path.mys ...

  2. [BZOJ4003]城池攻占

    Description 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池. 这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖, ...

  3. git将本地已经存在的分支和一个指定的远端分支建立映射关系

    Make an existing Git branch track a remote branch? Given a branch foo and a remote upstream: As of G ...

  4. 【线性判别】Fisher线性判别(转)

    今天读paper遇到了Fisher线性判别的变体, 所以来学习一下, 所以到时候一定要把PRMl刷一遍呀 以下两篇论文一起阅读比较好: 论文1: https://blog.csdn.net/Rainb ...

  5. DBUS及常用接口介绍

    [原文]  1. 概述 1.1  DBUS概述     DBUS是一种高级的进程间通信机制.DBUS支持进程间一对一和多对多的对等通信,在多对多的通讯时,需要后台进程的角色去分转消息,当一个进程发消息 ...

  6. jQuery获取属性值的方法

    1.利用绑定事件:     $(".callback").on("click","#knbh",function(){      ***** ...

  7. 简单易用的分页类实例代码PHP

    <?php /*********************************************** * @类名: page * @参数: $myde_total - 总记录数 * $m ...

  8. mac下安装c++开发环境

    mac下安装c++开发环境 1 注册apple id 按照apple注册步骤注册apple id,我注册时遇到如下问题 apple store完成创建apple id步骤中,选择付款方式和账单地址后, ...

  9. C++实现矩阵压缩

    C++实现矩阵压缩 转置运算时一种最简单的矩阵运算.对于一个m*n的矩阵M,他的转置矩阵T是一个n*m的矩阵,且T(i,j) = M(j,i). 一个稀疏矩阵的转置矩阵仍然是稀疏矩阵. 矩阵转置 方案 ...

  10. UVALive - 6709树套树

    题意:给你一个矩阵,q次操作,每次查询长宽l的矩阵最大值a和最小值b,然后把中间点换成floor((a+b)/2), 解法:暴力可过,建n颗线段树暴力更新,但是正解应该是树套树,树套树需要注意的是当建 ...