grunt之watch续
上一回没有说完,我就是这样,做之前心中波澜壮阔,锦绣山河,等画完小草开始烦躁,完成鲜花出现动摇,然后心神涣散,最后虎头蛇尾。
现在弥补下之前遗漏的问题。
watch(V0.6.1)的tasks和options(github地址)
- watch和之前介绍的plugin有几点不同,首先files的值不是原来对象数组的形式,而是监听的文件的路径的字符串数组。
其次,其他plugin的task结构为target+options,watch多一个属性类型,叫tasks,是监听的文件变动后需要执行的任务队列。
目录结构还是参照之前,源文件夹是src,目标文件夹是dest,先做一个简单的实现。'use strict'; module.exports = function(grunt) { require('load-grunt-tasks')(grunt);
require('time-grunt')(grunt); var path = {
src: 'src',
dest: 'dest'
} grunt.initConfig({
path: path,
copy: {
test: {
files: [
{
expand: true,
cwd: '<%=path.src%>/',
src: '{,*/}*',
dest: '<%=path.dest%>/'
}
]
}
},
watch: {
test: {
tasks: [
'copy'
],
files: '<%=path.src%>/{,*/}*'
}
}
}); grunt.registerTask('default', ['watch']);
}执行grunt后,源文件夹下每有文件的变动,就会将所有文件复制到目标文件夹。
- 开始介绍options
spawn: 是否在子进程中执行tasks,默认为true。相当概念化的东东,换种方式理解。我们在module.exports = function(grunt) 函数的开头加上一句console.log('task name: ' + (process.argv[2] || 'default'));process的nodejs中的api,这句话是打印输入的命令的第二个字符串即执行的task。比如你执行grunt default,第二个字符串就是default,执行grunt,第二个字符串就是undefined。
再次执行grunt,打印出来的内容如下task name: default
Running "watch" task
Waiting...然后修改源文件夹下的内容,接下来显示的内容如下
>> File "src\index.html" changed.
task name: copy
Running "copy:test" (copy) task
Created directories, copied files Done, without errors. Execution Time (-- :: UTC)
loading tasks 3ms ██████ %
copy:test 22ms █████████████████████████████
███████████ %
Total 26ms Completed in .309s at Tue Jan :: GMT+ (台北標準時間) - Waitin
g...又打印出了task name这一行,这意味着当设置此option为true时,每次执行watch中设置的task,都相当于在命令行再次输入grunt taskname。我们把此options设置为false,做同样的操作。
task name: default
Running "watch" task
Waiting...
>> File "src\index.html" changed. Running "copy:test" (copy) task
Created directories, copied files Running "watch" task
Completed in .043s at Tue Jan :: GMT+ (台北標準時間) - Waitin
g...没有再次执行输出task name的代码。
所以,如果你的Gruntfile.js中读取了输入命令的部分值并保存为变量,请将此option设置为false,不然watch启动的task中将读取不到这些变量。
- interrupt: 如果新的变动产生时之前watch启动的task还没执行完,是否中断执行,默认为false
- debounceDelay: 文件变动产生event的最小时间间隔,默认为500ms
- event: 触发监听器的文件变动event类型,可选参数'all'(default)、'changed'、'added'、'deleted'
- reload: 是否重新执行之前执行的命令,一般用于监听Gruntfile.js的变动,默认为false,保持之前spawn的代码,为watch添加一个target
config: {
options: {
reload: true,
spawn: false //按之前spawn的设置将只会打印一次task name
},
files: 'Gruntfile.js'
}执行grunt watch,然后修改Gruntfile.js,打印出来的内容
task name: watch
Running "watch" task
Waiting... Reloading watch config...
task name: watch Running "watch" task
Waiting...
>> File "Gruntfile.js" changed. Running "watch" task
Completed in .017s at Tue Jan :: GMT+ (台北標準時間) - Waitin
g...可见无视了spawn的设定,在本进程重新执行了原来的命令。
- dateFormat: Function,默认就是上面打印出来的时间
- atBegin: 是否在watch开启的时候执行一遍设定的tasks,默认false,样例中设置为true则执行grunt时会先进行一次copy
- livereload: 前一节已经提到过了
- cwd: 因为files不支持设置cwd,所以这里有个这样的option,和files中的功能一样
- livereload: task执行错误的时候是否进行livereload操作,默认为true
至此常用的plugin基本介绍结束,当然还有jshint、htmlmin、imagemin等,github上的链接已经给出,相信看过之前介绍的plugin会养成一种上github看文档的习惯。
下一篇介绍下module.exports = function(grunt){}中传入参数grunt的api,应该也是grunt系列的最后一篇了。
grunt之watch续的更多相关文章
- .Net Core MVC 网站开发(Ninesky) 2.3、项目架构调整(续)-使用配置文件动态注入
上次实现了依赖注入,但是web项目必须要引用业务逻辑层和数据存储层的实现,项目解耦并不完全:另一方面,要同时注入业务逻辑层和数据访问层,注入的服务直接写在Startup中显得非常臃肿.理想的方式是,w ...
- [.NET] C# 知识回顾 - 委托 delegate (续)
C# 知识回顾 - 委托 delegate (续) [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/6046171.html 序 上篇<C# 知识回 ...
- 初学seaJs模块化开发,利用grunt打包,减少http请求
原文地址:初学seaJs模块化开发,利用grunt打包,减少http请求 未压缩合并的演示地址:demo2 学习seaJs的模块化开发,适合对seajs基础有所了解的同学看,目录结构 js — —di ...
- grunt配置任务
这个指南解释了如何使用 Gruntfile 来为你的项目配置task.如果你还不知道 Gruntfile 是什么,请先阅读 快速入门 指南并看看这个Gruntfile 实例. Grunt配置 Grun ...
- 快速开发Grunt插件----压缩js模板
前言 Grunt是一款前端构建工具,帮助我们自动化搭建前端工程.它可以实现自动对js.css.html文件的合并.压缩等一些列操作.Grunt有很多插件,每一款插件实现某个功能,你可以通过npm命名去 ...
- 是时候搁置Grunt,耍一耍gulp了
也算是用了半年Grunt,几个月前也写过一篇它的入门文章(点此查看),不得不说它是前端项目的一个得力助手.不过技术工具跟语言一样日新月异,总会有更好用的新的东西把旧的拍死在沙滩上(当然Grunt肯定没 ...
- 应用Grunt自动化地优化你的项目前端
在不久前我曾写了一篇 应用r.js来优化你的前端 的文章,为大家介绍了r.js这个实用工具,它可以很好地压缩.合并前端文件并打包整个项目.但是如果将r.js放到项目中,我们不得不顾及到一个问题——项目 ...
- Grunt(页面静态引入的文件地址的改变探究)-V2.0
相关插件的引用: grunt-usemin 对页面的操作 grunt-contrib-cssmin 压缩css load-grunt-tasks 瘦身gruntfile grunt-rev给md5 ...
- Grunt基本使用-V1.0
浅语:grunt中文网:http://www.gruntjs.net/ 第一步:Grunt 依赖 Node.js 所以在安装之前确保你安装了 Node.js.然后开始安装 Grunt. 实际上,安装的 ...
随机推荐
- html、js简单实现含中文csv文件下载(后端为django)
1.在django views.py中使用HttpResponse views.py首行加上utf-8编码,将默认unicode编码变为utf-8 # -*- coding:utf-8 -*- 下面 ...
- Base:一种 Acid 的替代方案
原文链接: BASE: An Acid Alternative 数据库 ACID,都不陌生:原子性.一致性.隔离性和持久性,这在单台服务器就能搞定的时代,很容易实现,但是到了现在,面对如此庞大的访问量 ...
- NYOJ--128--前缀式计算(表达式求值)
前缀式计算 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 先说明一下什么是中缀式: 如2+(3+4)*5这种我们最常见的式子就是中缀式. 而把中缀式按运算顺序加上括 ...
- Java 运行期数据区
对于 Java 开发者来说,由虚拟机进行内存管理是把双刃剑,一方面免去了繁杂的内存管理工作,另一方面,一旦出现内存泄漏和溢出方面的问题,如果不了解虚拟机是怎样使用内存的,排查问题将成为一项艰难的工作. ...
- vue指令v-bind示例解析
1.绑定一个属性 <img id="app" v-bind:src="imageSrc"> <script> var app = Vue ...
- asp.net 程序,当发生找不到文件的错误时,如何正确定位是哪个文件?
需要在Global.asax.cs中添加Application_Error代码如下,在Log中查看是哪个文件缺失: protected void Application_Error(object se ...
- 开心的金明 NOIP 2006 普及组
题目描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:"你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过N元钱就 ...
- android学习SeekBar的使用
SeekBar介绍听歌的时候,我们常常想快进或者快退到某一时间段,听歌的时候我们控制音量大小听歌,SeekBar可以通过滑块的位置来标示数值,而且拖动条允许用户拖动滑块来改变进度条的大小 SeekBa ...
- 对lea与mov的理解
lea不止可以完成mov的功能,他还可以加载存储器的有效地址,即D<-&S 借鉴深度理解计算机系统里: 指令Leal实际上是movl指令的变形.他的指令形式是从存储器读数据到寄存器,但实 ...
- WEB测试常见BUG
翻页 翻页时,没有加载数据为空,第二页数据没有请求 翻页时,重复请求第一页的数据 翻页时,没有图片的内容有时候会引用有图片的内容 2.图片数据为空 图片数据为空时,会保留为空的图片数据位置 ...