javascript - Grunt 任务陷入无限循环

标签 javascript node.js gruntjs npm grunt-contrib-concat

正在为一些即将开展的项目构建基础 Gruntfile.js。从一台新电脑开始,一切都是全新的。使用 Homebrew 安装了 Node 和 NPM,然后在全局以及我的本地目录中安装了 Grunt。

这是我的package.json:

{
  "name": "timespent-prototype",
  "version": "0.1.0",
  "devDependencies": {
    "assemble": "0.4.37",
    "bower": "^1.4.1",
    "grunt": "^0.4.5",
    "grunt-contrib-concat": "^0.5.1",
    "grunt-contrib-sass": "^0.9.2",
    "grunt-contrib-watch": "^0.6.1",
    "grunt-newer": "^1.1.0",
    "grunt-wiredep": "^2.0.0"
  }
}

这是我的 Gruntfile.js:

module.exports = function(grunt) {

  // Project configuration.
  grunt.initConfig({
    pkg: grunt.file.readJSON('package.json'),

    concat: {
      vendor: {
       src: ['vendor/**/*.min.js'],
       dest: 'build/javascripts/library.js',
      }
    },

    // Takes your scss files and compiles them to css
    sass: {
      dist: {
        options: {
          style: 'expanded'
        },
        files: {
          'build/stylesheets/application.css': 'app/stylesheets/application/index.scss'
        }
      }
    },

    // Assembles your templates into HTML files
    assemble: {
      options: {
        layoutdir: 'app/views/layouts/',
        partials: ['app/views/partials/*.hbs'],
        flatten: true,
        expand: true
      },
      pages: {
        src: ['app/views/**/*.hbs','!app/views/layouts/*.hbs','!app/views/partials/*.hbs'],
        dest: 'build/'
      }
    },

    wiredep: {
      task: {
        src: ['app/views/layouts/*.hbs']
      }
    },

    // Watches for file changes, runs the default task
    watch: {
      files: ['app/**/*'],
      tasks: ['default'],
      options: {
        // Start another live reload server on port 1337
        livereload: 1337,
      }
    }

  });

  // Load the plugins
  grunt.loadNpmTasks('assemble');
  grunt.loadNpmTasks('grunt-contrib-sass');
  grunt.loadNpmTasks('grunt-contrib-watch');
  grunt.loadNpmTasks('grunt-newer');
  grunt.loadNpmTasks('grunt-contrib-concat');
  grunt.loadNpmTasks('grunt-wiredep');

  // Register the tasks
  grunt.registerTask('default', ['sass','assemble']);
  grunt.registerTask('watch', ['watch']);
  grunt.registerTask('concat', ['concat']);
  grunt.registerTask('wiredep', ['wiredep']);
};

我看到的问题是,对于多个任务,这里特别是 wiredepconcat,任务会陷入循环,永远不会结束。运行 grunt concat,输出如下所示:

Registering "grunt-contrib-concat" local Npm module tasks.
Reading /Users/jacksonlynch/projects/timespent-prototype/node_modules/grunt-contrib-concat/package.json...OK
Parsing /Users/jacksonlynch/projects/timespent-prototype/node_modules/grunt-contrib-concat/package.json...OK
Loading "concat.js" tasks...OK
+ concat

Running tasks: concat

Running "concat" task

Running "concat" task

Running "concat" task

Running "concat" task

Running "concat" task

Running "concat" task

Running "concat"task 将继续打印,直到我停止它。正如我在多个插件和任务中看到的那样,这可能是我安装 NPM 或 Grunt 的问题,但我很难调试它。如果有人以前遇到过这个问题,请告诉我有什么帮助!

谢谢!


编辑:为了回应 Alireza Ahmadi 的评论,这是我的文件结构:

.
|
|_ app/
  |_ assets/
  |_ javascript/
  |_ stylesheets/
  |_ views/
|
|_ build/
  |_stylesheets/
  |_javascripts/
|
|_ vendor/
|_ bower.json
|_ Gruntfile.js
|_ package.json

最佳答案

Gruntfile.js 的最后两行中,您重新声明了 concatwiredep 任务,并且当 grunt 尝试运行您的代码时, 它陷入了无限循环,因为 concat 引用了一个未定义的 concat 任务,所以你应该删除这些行:

grunt.registerTask('concat', ['concat']);
grunt.registerTask('wiredep', ['wiredep']);

一般来说,当你用grunt.initConfig定义一个名为foobar的任务时,它被定义并且不需要使用registerTask注册并且它可以通过 grunt foobar 命令访问。

关于javascript - Grunt 任务陷入无限循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30687746/

相关文章:

javascript - 对象字面量未定义

javascript - 等待文档 mousedown 完成,然后元素 onclick 才能开始

node.js - sequelize 错误模型与另一个模型无关

css - CSS 和 Grunt 缩小中的相对路径?

Windows 安装 PhantomJS 失败

javascript - Leap Motion JS - 后台更新

php - 订购 XML 记分板并使用 PHP 返回

javascript - Dropbox JS大量writeFile不写入所有文件

javascript - AWS S3 createPresignedPost URL 可以上传任何大小的文件,尽管有限制

javascript - 如何修复此错误 : Grunt build not found, 使用 --force 继续