如何配置grunt-contrib-less以生成与Chrome DevTools兼容的源映射?

11

问题标题已经说明了一切。我不知道如何配置现在支持源映射的grunt-contrib-less任务。我的期望结果是Chrome DevTools CSS检查器指向Less规则。如果可能的话,最好将源映射内联到同一输出的CSS文件中,以避免使用单独的源映射文件使我的工作区混乱。

谢谢

2个回答

12

这是我的gruntfile.js,它可运行。

更新到grunt-contrib-less v0.9.0很重要,使用"XXX.css.map"而不是"XXX.map"也很重要。并且在给出正确的sourcebasepath后,它可以工作。在下面,我将发布来自结果.map文件的摘录。

gruntfile.js

module.exports = function(grunt) {
  grunt.initConfig({
    less: {
      development: {
        options: {
          compress: false,
          yuicompress: false,
          optimization: 2,
          sourceMap: true,
          sourceMapFilename: "assets/style/bootstrap.css.map",
          sourceMapBasepath: "assets/style/"
        },
        files: {
          // target.css file: source.less file
          "assets/style/bootstrap.css": "assets/style/bootstrap.less"
        }
      }
    },
    watch: {
      styles: {
        // Which files to watch (all .less files recursively in the less directory)
        files: ['assets/style/theme/**/*.less'],
        tasks: ['less'],
        options: {
          nospawn: true
        }
      }
    }
  });

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

  grunt.registerTask('default', ['watch']);
};

这是从使用lessc生成的.map文件中摘录出来的内容,当然它是有效的:

{"version":3,"file":"bootstrap.css","sources":["theme/page-welcome.less","bootstrap-2.3.2/mixins.less"...

这是一个从grunt-contrib-less 0.9.0生成的.map文件中摘录的内容,它也可以正常工作:

{"version":3,"sources":["theme/page-welcome.less","bootstrap-2.3.2/mixins.less","theme/page-work.less"...

敬祝好运, 斯特凡


1
这是一个很好的答案并且有效,我希望他们能够添加对--source-map-map-inline的支持,这样就会更加简单,因为它将地图内联到CSS中,消除了对basepath和单独的地图文件的需求 - 对于开发来说非常完美。 - bloke_zero

2

首先,您需要确保grunt-contrib-less正在运行支持源映射的版本。最新版本为0.9.0,因此请更新您的package.json文件中使用的版本,如下所示:

"dependencies" : {
    ...[other dependencies]...
    "grunt-contrib-less" : "0.9.0"
}

现在,在命令行中调用npm install来安装更新。


接下来,在你的Gruntfile.js文件中,为你的项目配置源映射。

你可以参考这里的指南:http://robdodson.me/blog/2012/12/28/debug-less-with-chrome-developer-tools/或这里:http://roots.io/using-less-source-maps/,但以下是一个示例配置:

    less : {
        development : {
            options : {
                strictImports : true,
                sourceMap: true,
                sourceMapFilename: '../css/common.css.map',
                sourceMapURL: 'http://localhost/css/common.css.map'
            },
            files : {
                '../css/common.css' : '../less/common.less'
            }
        },
    },

关键是确保你用于sourceMapURL的内容是一个实际可在浏览器中打开的URL。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接