如今 watch 中已經集成了 livereload ,因此把它們放在一塊兒說明。javascript
watch 能夠監控特定的文件,在添加文件、修改文件、或者刪除文件的時候自動執行自定義的任務,好比 livereload 等等。css
項目定義在 GitHub 上,地址:https://github.com/gruntjs/grunt-contrib-watchhtml
能夠經過 NPM 直接進行安裝前端
npm install grunt-contrib-watch --save-dev
安裝以後,須要在 Gruntfile.js 中添加任務的註冊。java
grunt.loadNpmTasks('grunt-contrib-watch');
經過 grunt watch 運行 watch 任務。 node
與 connect 相似,在 watch 下面定義本身的子任務,下面的示例將會監控 src 目錄下的任意 *.html 文件,在文件被修改以後,輸出被修改的文件名。git
這裏經過 watch 的事件進行處理。github
'use strict'; module.exports = function (grunt) { // Project configuration. grunt.initConfig({ watch:{ start:{ files: ['src/*.html'] } } }); grunt.event.on('watch', function(action, filepath, target) { grunt.log.writeln(target + ': ' + filepath + ' has ' + action); }); grunt.loadNpmTasks('grunt-contrib-watch'); }
咱們啓動 watch 任務,注意這個任務會持續監控。npm
PS C:\study\grunt> grunt watch Running "watch" task Waiting... start: src\index.html has changed >> File "src\index.html" changed. Completed in 0.001s at Sun Sep 06 2015 14:52:52 GMT+0800 (China Standard Time) - Waiting...
這裏咱們使用了 files 參數,這個參數能夠爲一個路徑字符串或者一個字符串的數組,做爲監控的目標。路徑的寫法能夠參考:Grunt 之通配符api
多數狀況下,咱們但願在文件發生變化以後,直接執行特定的任務,好比在修改了 *.js 的腳本文件以後,自動進行文件檢查。這能夠經過 tasks 來直接聲明。
這裏的 jshint 是咱們後面會講到的一個 javascript 語法檢查庫,如今還不能用呀。
watch: { scripts: { files: ['**/*.js'], tasks: ['jshint'] }, },
這裏咱們自定義一個名爲 hello 的任務。
tasks 是一個任務名稱的字符串或者,一個任務名稱的字符串數組,做爲咱們執行的任務。
'use strict'; module.exports = function (grunt) { // Project configuration. grunt.initConfig({ watch:{ start:{ files: ['src/*.html'], tasks: ['hello'] } } }); grunt.registerTask('hello', 'Hello, world task description.', function() { grunt.log.writeln('Hello, world.'); }); grunt.loadNpmTasks('grunt-contrib-watch'); }
能夠經過 options 配置更加詳細的設置。
boolean 類型,默認 true。默認會建立一個新的子進程來執行觸發的任務。經過設置爲 false,可使得觸發的任務能夠共享進程上下文,而且提升速度。可是,這會致使監控任務容易崩潰,因此,請儘可能使用這個特性,在新的子進程中執行任務。
watch: { scripts: { files: ['**/*.js'], tasks: ['jshint'], options: { spawn: false, }, }, },
boolean 類型,默認爲 false。仍是和進程相關。
在文件發生修改的時候,會生成子進程來執行任務,默認的行爲是對於每一個目標來講,在上一個處理完成以後,僅僅生成一個新的子進程來執行任務。設置 interrupt 爲 true,將會致使停止上一個進程,生成一個新進程來處理最後的變動。
watch: { scripts: { files: '**/*.js', tasks: ['jshint'], options: { interrupt: true, }, }, },
這是整數類型的參數,若是一樣的文件或者路徑被修改,須要等待多長時間才觸發事件。默認 500 毫秒。
watch: { scripts: { files: '**/*.js', tasks: ['jshint'], options: { debounceDelay: 250, }, }, },
字符串或者數組,默認爲 'all'
指定監控目標的特定事件類型,能夠爲 'all', 'changed', 'added' 和 'deleted'.
watch: { scripts: { files: '**/*.js', tasks: ['generateFileManifest'], options: { event: ['added', 'deleted'], }, }, },
boolean 類型參數,默認爲 false。
默認狀況下,若是 Gruntfile.js 文件被監控,在這個文件被修改以後,會致使監控任務從新啓動。而且從新加載 Gruntfile.js。
若是 reload 設置爲 true,任何被監控文件的修改都會致使監控任務從新啓動。除非你的 Gruntfile.js 依賴於其它文件,不然不使用這個參數。
watch: { configFiles: { files: [ 'Gruntfile.js', 'config/*.js' ], options: { reload: true } } }
boolean 類型參數,默認爲 true。
這個整個任務級別的參數,不能在單個目標上配置。默認狀況下,監控任務會處理 grunt.fatal 和 grunt.warn ,防止致使的退出監控問題。若是你不但願監控任務覆蓋 grunt.fatal 和 grunt.warn ,能夠將 forever 設置爲 false。
options.atBegin
boolean 類型,默認爲 false。
在監控任務啓動的時候,自動觸發對應的任務。
字符串或者對象類型,默認爲 process.cwd()
設置當前的工做目錄,默認爲 process.cwd(),能夠設置爲字符串的目錄來定義監控和產生的子任務的目錄,或者一個對象來描述各自獨立的路徑。
options: { cwd: { files: 'match/files/from/here', spawn: 'but/spawn/files/from/here' } }
這就是配合 connect 的 livereload 了。咱們單獨拿出來講明。
它是 options 的一個屬性,類型爲 boolean, 數值,或者配置對象。默認爲 false
設置爲 true 等價設置爲 35729.
實際上,會啓用一個支持從新加載的服務器,這個服務器工做在上述端口號上,經過這個服務器能夠獲取一個腳本,當文件被修改以後,經過這個腳本通知前端瀏覽器自動從新加載內容。
例如:
watch: { css: { files: '**/*.sass', tasks: ['sass'], options: { livereload: true, }, }, },
啓動以後,實際上在指定的端口上建立了一個服務器,若是訪問的話,能夠看到返回的信息。
訪問:http://localhost:35729/
返回的內容
{"tinylr":"Welcome","version":"0.0.5"}
須要的話,還能夠工做在 https 上,那就須要經過 key 和 cert 進行配置了。
watch: { css: { files: '**/*.sass', tasks: ['sass'], options: { livereload: { port: 9000, key: grunt.file.read('path/to/ssl.key'), cert: grunt.file.read('path/to/ssl.crt') // you can pass in any other options you'd like to the https server, as listed here: http://nodejs.org/api/tls.html#tls_tls_createserver_options_secureconnectionlistener } }, }, },
更多內容能夠查看 enable livereload on your HTML.