我的项目是一个非常基本的yo/angle项目。我有以下cssmin配置。
useminPrepare: {
html: '<%= yeoman.app %>/index.html',
options: {
dest: '<%= yeoman.dist %>',
flow: {
html: {
steps: {
js: ['concat', 'uglifyjs'],
css: ['cssmin']
},
post: {}
}
}
}
},
...
cssmin: {
dist: {
files: {
'<%= yeoman.dist %>/styles/main.css': [
'.tmp/styles/{,*/}*.css'
]
}
}
},
...
grunt.registerTask('build', [
'clean:dist',
'wiredep',
'useminPrepare',
'concurrent:dist',
'autoprefixer',
'concat',
'ngAnnotate',
'copy:dist',
'cdnify',
'cssmin',
'uglify',
'filerev',
'usemin',
'htmlmin'
]);
当我运行grunt构建时,出现以下错误:
Running "cssmin:generated" (cssmin) task
Warning: Path must be a string. Received undefined Use --force to continue.
Aborted due to warnings.
Execution Time (2016-05-26 00:57:04 UTC)
concurrent:dist 15s
autoprefixer:server 3.3s
ngAnnotate:dist 3.6s
cdnify:dist 10.7s
cssmin:dist 888ms
Total 34.6s
我在其他帖子上看到了此错误,但没有使用 cssmin。 我已经将 package.json 中的库升级到最新版本,这可能是原因。
这个项目一度建设得很好。 我无法确定缺少什么路径。 有谁知道我错过了哪条路?
实际上这个问题已经解决了,请更新v1.0.2的版本链接在这里
上述回复中提到的答案对我有用。
所以在node_modules/grunt-contrib-cssmin/tasks/cssmin.js,在第 41 行,向参数添加一个 OR 空字符串:
//before
options.relativeTo = path.dirname(availableFiles[0]);
//after
options.relativeTo = path.dirname(availableFiles[0] || '');
从:https://github.com/gruntjs/grunt-contrib-cssmin/pull/271/commits/11e655873dfa58b6edcda0113cee612f7a6b2ab9?diff=split
编辑:答案现已过时,请参阅下面的 https://stackoverflow.com/a/39482214/1215723
运行详细选项的详细信息:
youri$ grunt -v
Running "cssmin:generated" (cssmin) task
Verifying property cssmin.generated exists in config...OK
Files: [no src] -> dist/styles/vendor.css
Files: .tmp/styles/main.css -> dist/styles/main.css
Options: rebase=false, report="min", sourceMap=false
Warning: Path must be a string. Received undefined Use --force to continue.
看来我们并不孤单。通过跟踪问题面包屑,我发现:
- 发电机角度 #1218
- 清洁 CSS #774
- 节点 #5348
建议的解决方法是降级到节点 v5,事实上,它有效(对我来说)。如果您觉得更方便,也可以安装节点版本管理器。
你只需要:
在您的包中更改此内容.json
"grunt-contrib-cssmin": "^1.0.2",
然后
npm install