准备工作:grunt基于node环境运行,所有先安装node.js

1.安装grunt,通过node的npm的包管理工具

 >npm install grunt --save-dev

2.npm init在项目中引导创建一个package.json文件

>npm init

3.新建一个Gruntfile的js文件,主要是写入grunt的配置

module.exprots = function(grunt){

grunt.initConfig({此处写配置的信息})

}

 4.几个常用的插件

   (1)less监听

>npm install grunt-contrib-less --save-dev

a.配置信息:

less:{development: {files: {'public/css/home/home.css': 'public/css/home/home.less'}}}

b.注册信息:

grunt.loadNpmTasks('grunt-contrib-less')

c.运行:

>grunt less

   (2)watch监听

>npm install grunt-contrib-watch --save-dev

a.配置信息:

watch:{css: {files: [ 'public/css/home/home.less'],tasks:['less'],options:{livereload:true}}}

b.注册信息:

grunt.loadNpmTasks('grunt-contrib-watch')

c.运行:

>grunt watch

   (3)浏览器同步测试工具

>npm install browser-sync --save-dev

a.配置信息:

不需要配置信息

b.注册信息:

不需要注册信息

c.运行:

>browser-sync start --server --file "*.html"

   (4)css压缩

>npm install grunt-contrib-cssmin --save-dev

a.配置信息:

cssmin: {
target: {
files: [{
expand: true,
cwd: 'public/css/home', //需要压缩的css路径
src: ['*.css', '!*.min.css'], //需要压缩的css
dest: 'build/css/home', //压缩之后的路径
ext: '.min.css' //压缩之后的css后缀名
}]
}
}

b.注册信息:

grunt.loadNpmTasks('grunt-contrib-cssmin')

c.运行:

>grunt cssmin

   (5)js合并压缩

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

a.配置信息:

uglify: {
my_target: {
files: {
'build/js/home/home.min.js': ['public/js/home/home1.js', 'public/js/home/home2.js']
}
}
}

b.注册信息:

grunt.loadNpmTasks('grunt-contrib-uglify')

c.运行:

>grunt uglify

   (6)合并css和js

>npm install grunt-contrib-concat --save-dev

a.配置信息:

concat:{
js:{
files:{
'build/js/home/concat.js':['public/js/home/*.js']
}
},
css:{
files:{
'build/css/home/concat.css':['public/css/home/*.css']
}
}
}

b.注册信息:

grunt.loadNpmTasks('grunt-contrib-concat')

c.运行:

>grunt concat

   (7)css精灵

>npm install grunt-spritesmith --save-dev

a.配置信息:

sprite:{
all:{
src:["public/img/*.png","public/img/*.jpg"], //需要整理的图片
dest:"build/img/spriteRes.png", //生成一张图片的名称
destCss:"build/css/spriteRes.css" //生成css的路径和文件名
}
}

b.注册信息:

grunt.loadNpmTasks('grunt-spritesmith')

c.运行:

>grunt sprite

   (8)图片压缩

>npm install grunt-contrib-imagemin --save-dev

a.配置信息:

imagemin:{
release:{
files:[{
expand:true,
src:['build/img/spriteRes.png']
}],
options:{
optimizationLevel:3
}
}
}

b.注册信息:

grunt.loadNpmTasks('grunt-contrib-imagemin')

c.运行:

>grunt imagemin

   (9)注册多任务执行

  grunt.registerTask('default', ['uglify', 'cssmin', 'concat', 'imagemin']);

grunt构建一个项目的更多相关文章

  1. 使用 gulp 构建一个项目

    本章将介绍 gulp-watch-path stream-combiner2 gulp-sourcemaps gulp-autoprefixer 您还可以直接学习以下模块: 安装 Node 和 gul ...

  2. 基于Grunt构建一个的项目

    没有搭建环境的,请参考<Grunt自动化构建环境搭建 >,搭建完成后 新建一个项目目录,这里建立一个“Demo”目录 运行CMD,并进入这个目录,运行 npm install grunt ...

  3. 使用grunt构建前端项目

    1. grunt构建工具是基于nodejs上的,所以在使用之前一定要先安装好nodejs 2. 安装好nodejs后,node -v查看node版本 npm-v 查看npm版本信息 3. 在需要用到的 ...

  4. Vue+webpack构建一个项目

    1.安装CLI命令的工具  推荐用淘宝的镜像 npm install -g @vue/cli @vue/cli-init 2.使用命令构建一个名为myapp的项目 vue init webpack m ...

  5. 2016-7-15(1)使用gulp构建一个项目

    gulp是前端开发过程中自动构建项目的工具,相同作用的还有grunt.构建工具依 靠插件能够自动监测文件变化以及完成js/sass/less/html/image/css/coffee等文件的语法检查 ...

  6. 使用gulp构建一个项目

    gulp是前端开发过程中自动构建项目的工具,相同作用的还有grunt.构建工具依靠插件能够自动监测文件变化以及完成js/sass/less/html/image/css/coffee等文件的语法检查. ...

  7. 基于Grunt构建一个JavaScript库

    现在公认的JavaScript典型项目需要运行单元测试,合并压缩.有些还会使用代码生成器,代码样式检查或其他构建工具. Grunt.js是一个开源工具,可以帮助你完成上面的所有步骤.它非常容易扩展,并 ...

  8. 使用grunt构建seajs项目

    1.安装nodejs 2.安装grunt-cli npm install -g grunt-cli 3.进入到项目目录,同时准备好package.json和Gruntfile.js文件 //packa ...

  9. Django 构建一个项目

    一.创建django程序 终端命令:django-admin startproject fahaicmd IDE创建Django程序时,本质上都是自动执行上述命令 其他常用命令: python man ...

随机推荐

  1. noscript 标签,一个被忽视的重要标签

    打开 Drupal 的新后台,发现显示大面积空白 .本以为是 CSS 的问题,后来折腾好久才发现是我之前因为某些站的安全问题把浏览器的 Javascript 给禁用了.Javascript 的日益强大 ...

  2. java 制作QQ登录界面

    package org.eclipse.wb.swing; import java.awt.BorderLayout;import java.awt.EventQueue; import javax. ...

  3. java+++IO流操作

    序:IO流的操作主要分为两种读和写.一方面:我们可以通过不加缓冲类字符流BufferedReader/Writer和字节流BufferedInputStream/OutputStream来进行简单的读 ...

  4. JVM运行和类加载过程

    JAVA的JVM的内存可分为3个区:堆(heap).栈(stack)和方法区(method) (该知识点引用 http://www.cnblogs.com/dingyingsi/p/3760730.h ...

  5. MySQL创建数据库与创建用户以及授权

    1.create schema [数据库名称] default character set utf8 collate utf8_general_ci;--创建数据库 采用create schema和c ...

  6. 关于VS2013的编码的UI测试。

    1.  打开VS2013,选择文件→新建→项目 2.  弹出的选项左侧选择visual C#中的测试,中间选择框选择编码的UI测试项目,确定后就产生的测试项目. 3.  弹出框选择默认的录制操作巴拉巴 ...

  7. HTML5初步了解

        一.使用HTML5的十大原因 你难道还没有考虑使用HTML5? 当然我猜想你可能有自己的原因:它现在还没有被广泛的支持,在IE中不好使,或者你就是喜欢写比较严格的XHTML代码.HTML5是w ...

  8. 【转】请求处理机制其三:view层与模板解析

     进入 View 了 如果处理过程这时候还在继续的话,处理器会调用 view function.Django 中的 Views 不很严格因为它只需要满足几个条件: 必须可以被调用. 必须接受 djan ...

  9. 用js写倒计时,向列表添加数据-------2017-03-21

    一.单选按钮确定提交是否可用 <input id="a" type="radio" name="a"  onclick="c ...

  10. C++ Primer 5 CH5 语句

    5.1 简单语句 空语句: ; 5.2 语句作用域 5.3 条件语句 switch 语句:表达式与某个 case 匹配成功,执行 case 之后的语句直到 break 或者 switch 结尾,cas ...