首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无休止循环中的咕噜任务

无休止循环中的咕噜任务
EN

Stack Overflow用户
提问于 2015-06-06 21:28:58
回答 1查看 3.2K关注 0票数 6

为一些即将到来的项目准备一个基本的Gruntfile.js。从一台新电脑开始,所以一切都是全新的。使用Homebrew安装Node和NPM,然后全局安装Grunt,以及我的本地目录。

这是我的package.json

代码语言:javascript
复制
{
  "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

代码语言:javascript
复制
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

代码语言:javascript
复制
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的评论,以下是我的文件结构:

代码语言:javascript
复制
.
|
|_ app/
  |_ assets/
  |_ javascript/
  |_ stylesheets/
  |_ views/
|
|_ build/
  |_stylesheets/
  |_javascripts/
|
|_ vendor/
|_ bower.json
|_ Gruntfile.js
|_ package.json
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-06-06 22:10:12

Gruntfile.js的最后2行中,您重新声明了concatwiredep任务,当grunt试图运行您的代码时,它陷入了一个没完没了的循环,因为concat指的是一个未定义的concat任务,因此您应该删除这些行:

代码语言:javascript
复制
grunt.registerTask('concat', ['concat']);
grunt.registerTask('wiredep', ['wiredep']);

通常,当您用foobar定义任务时,它是定义的,不需要使用registerTask注册,并且可以通过grunt foobar命令访问它。

票数 18
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30687746

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档