我有个问题。我在我的项目中使用https://github.com/vanetix/grunt-includes,安装后我的 livereload 插件停止工作,我在编辑 html 文件时看不到更改。你能帮帮我吗?
我的咕噜声文件:
'use strict';
var lrSnippet = require('grunt-contrib-livereload/lib/utils').livereloadSnippet;
var mountFolder = function(connect, dir) {
return connect.static(require('path').resolve(dir));
};
module.exports = function(grunt) {
// load all grunt tasks
require('matchdep').filterDev('grunt-*').forEach(grunt.loadNpmTasks);
// configurable paths
var yeomanConfig = {
app: 'app',
dist: 'dist'
};
grunt.initConfig({
yeoman: yeomanConfig,
watch: {
coffee: {
files: ['app/js/*.coffee'],
tasks: ['coffee:dist']
},
coffeeTest: {
files: ['test/spec/*.coffee'],
tasks: ['coffee:test']
},
less: {
files: ['app/less/**/*.less'],
tasks: ['less']
},
includes: {
files: ['app/*.html', '.tmp/*.html'],
tasks: ['includes:server']
},
livereload: {
files: [
'app/*.html',
'{.tmp,app}/css/*.css',
'{.tmp,app}/js/*.js',
'{.tmp,app}/widgets/**/*.js',
'app/img/*.{png,jpg,jpeg}'
],
tasks: ['livereload']
}
},
connect: {
options: {
port: 9000
},
livereload: {
options: {
middleware: function(connect) {
return [
lrSnippet,
mountFolder(connect, '.tmp'),
mountFolder(connect, 'app')
];
}
}
},
test: {
options: {
middleware: function(connect) {
return [
mountFolder(connect, '.tmp'),
mountFolder(connect, 'test')
];
}
}
},
dist: {
options: {
middleware: function(connect) {
return [
mountFolder(connect, 'dist')
];
}
}
}
},
open: {
server: {
url: 'http://localhost:<%= connect.options.port %>'
}
},
clean: {
dist: ['.tmp', 'dist/*'],
server: '.tmp'
},
// jshint: {
// options: {
// jshintrc: '.jshintrc'
// },
// all: [
// 'Gruntfile.js',
// 'app/js/*.js',
// 'test/spec/*.js'
// ]
// },
mocha: {
all: ['http://localhost:3501/index.html']
},
coffee: {
dist: {
files: {
'.tmp/js/coffee.js': 'app/js/*.coffee'
}
},
test: {
files: [{
expand: true,
cwd: '.tmp/spec',
src: '*.coffee',
dest: 'test/spec'
}]
}
},
includes: {
build: {
cwd: 'app',
src: ['*.html', 'pages/*.html'],
dest: 'dist',
options: {
flatten: true,
banner: ''
}
},
server: {
cwd: 'app',
src: ['*.html', 'pages/*.html'],
dest: '.tmp/',
options: {
flatten: true,
banner: ''
}
}
},
less: {
options: {
paths: ['app/less'],
//dumpLineNumbers: true
},
dist: {
files: [{
expand: true, // Enable dynamic expansion.
cwd: 'app/css/', // Src matches are relative to this path.
src: ['**/*.less'], // Actual pattern(s) to match.
dest: '.tmp/css/', // Destination path prefix.
ext: '.css', // Dest filepaths will have this extension.
}],
},
server: {
files: [{
expand: true, // Enable dynamic expansion.
cwd: 'app/less/', // Src matches are relative to this path.
src: ['**/*.less'], // Actual pattern(s) to match.
dest: '.tmp/css/', // Destination path prefix.
ext: '.css', // Dest filepaths will have this extension.
}],
}
},
// not used since Uglify task does concat,
// but still available if needed
/*concat: {
dist: {}
},*/
// requirejs: {
// dist: {
// // Options: https://github.com/jrburke/r.js/blob/master/build/example.build.js
// options: {
// // `name` and `out` is set by grunt-usemin
// baseUrl: 'app/js',
// optimize: 'none',
// // TODO: Figure out how to make sourcemaps work with grunt-usemin
// // https://github.com/yeoman/grunt-usemin/issues/30
// //generateSourceMaps: true,
// // required to support SourceMaps
// // http://requirejs.org/docs/errors.html#sourcemapcomments
// preserveLicenseComments: false,
// useStrict: true,
// wrap: true,
// //uglify2: {} // https://github.com/mishoo/UglifyJS2
// mainConfigFile: 'app/js/main.js'
// }
// }
// },
useminPrepare: {
html: 'app/*.html',
options: {
dest: 'dist'
}
},
usemin: {
html: ['dist/*.html'],
css: ['dist/css/*.css'],
options: {
dirs: ['dist']
}
},
imagemin: {
dist: {
files: [{
expand: true,
cwd: 'app/img',
src: '**/*.{png,jpg,jpeg}',
dest: 'dist/img'
}]
}
},
cssmin: {
dist: {
files: {
'dist/css/main.css': [
'.tmp/css/*.css',
'app/css/*.css'
]
}
}
},
htmlmin: {
dist: {
options: {
removeCommentsFromCDATA: true,
// https://github.com/yeoman/grunt-usemin/issues/44
//collapseWhitespace: true,
collapseBooleanAttributes: true,
removeAttributeQuotes: true,
removeRedundantAttributes: true,
useShortDoctype: true,
removeEmptyAttributes: true,
removeOptionalTags: true
},
files: [{
expand: true,
cwd: 'app',
src: '**/*.html',
dest: 'dist'
}]
}
},
copy: {
dist: {
files: [{
expand: true,
dot: true,
cwd: 'app',
dest: 'dist',
src: [
'*.{ico,txt}',
//'*.html',
'fonts/*.*',
'.htaccess'
]
}]
}
},
bower: {
rjsConfig: 'app/js/main.js',
indent: ' '
}
});
grunt.renameTask('regarde', 'watch');
// remove when mincss task is renamed
grunt.renameTask('mincss', 'cssmin');
grunt.loadNpmTasks('grunt-includes');
grunt.registerTask('server', function(target) {
if (target === 'dist') {
return grunt.task.run(['open', 'connect:dist:keepalive']);
}
grunt.task.run([
'clean:server',
'coffee:dist',
'less:server',
'includes:server',
'livereload-start',
'connect:livereload',
'open',
'watch'
]);
});
grunt.registerTask('test', [
'clean:server',
'coffee',
'less',
'connect:test',
'mocha'
]);
grunt.registerTask('build', [
'clean:dist',
'test',
'coffee',
'less:dist',
'useminPrepare',
'includes:build',
'imagemin',
'cssmin',
'htmlmin',
'concat',
'uglify',
'copy',
'usemin'
]);
grunt.registerTask('default', ['build']);
};
编辑:
我只是将包括:服务器移动到 liverelad 功能,它的工作。
livereload: {
files: [
'app/*.html',
'{.tmp,app}/css/*.css',
'{.tmp,app}/js/*.js',
'{.tmp,app}/widgets/**/*.js',
'app/img/*.{png,jpg,jpeg}'
],
tasks: ['livereload', 'includes:server']
}