javascript - Angular : Error after concat angular js files into single js file with gulp

标签 javascript angularjs gulp gulp-concat

我正在使用 gulp-concat 将所有 angular js 文件合并为一个,但是在运行 gulp task 之后,我在运行应用程序时在 chrome 控制台中收到此错误:

angular.js:13708Error: [ng:areq] http://errors.angularjs.org/1.5.7/ng/areq?p0=userboxController&p1=not%20a%20function%2C%20got%20undefined

我的 gulp 任务:

gulp.task('scripts', function () {
  return gulp.src(['js/app/*.js', 'components/*/*/*.js'])  
    .pipe(concat('appscript.js'))
    .pipe(minify()) 
    .pipe(gulp.dest('./dist/js/'));
});

gulp-concat 将专用的 angular js 文件合并到 appscript.js 中,例如:

angular.module('app',[]);     


angular
    .module("app", [])
    .controller("paymentCtrl", ['$scope', '$http', function ($scope, $http) {
        $http.get('data/payments.json').then(function (payments) {
            $scope.payments = payments.data;
        });

        $scope.saveEntity = function () {
            console.info("goog");
        }
    }]); 

angular
    .module("app",[])
    .controller("userboxController", ['$scope', '$http',function ($scope, $http, usersService) {
        usersService.getCurrentUser().then(function (user) {
            $scope.user = user.data;
        });
    }]);


angular
    .module("app",[])
    .controller("usersController",['$scope', '$http','usersService', function ($scope, $http, usersService) {
        usersService.getAll().then(function (users) {
            $scope.users = users.data;
        });
    }]); 


angular
    .module("app", [])
    .directive('usersGrid', function () {
        return {
             templateUrl : 'components/users/template/grid.html'
        }
    }); 

Angular 有什么问题?!!

最佳答案

这不是合并相关的问题。

你每次都在制作应用程序模块

angular.module('app', [])

您只需在一个地方初始化模块,并且每次都将使用带有 ~ [] 括号的相同模块。

请找到plunker here

var myApp = angular.module('app');

myApp.controller("paymentCtrl", ['$scope', '$http', function($scope, $http) {
  $http.get('data/payments.json').then(function(payments) {
    $scope.payments = payments.data;
  });

  $scope.saveEntity = function() {
    console.info("goog");
  }
}]);

myApp.controller("userboxController", ['$scope', '$http',       function($scope, $http, usersService) {
  $scope.user = 'abc';

}]);


myApp.controller("usersController", ['$scope', '$http', 'usersService', function($scope, $http, usersService) {
  usersService.getAll().then(function(users) {
    $scope.users = users.data;
  });
}]);


myApp.directive('usersGrid', function() {
  return {
    templateUrl: 'components/users/template/grid.html'
  }
});

关于javascript - Angular : Error after concat angular js files into single js file with gulp,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38140339/

相关文章:

javascript - 使用 Google 脚本删除行将破坏另一个工作表中的引用

javascript - 如何在 javascript 中将条件语句添加到 - tic - tac - toe game tie 函数?

javascript - JSON发送的数据始终为空

javascript - 如何以 Angular 显示对象数组中的文本

forms - 运行 Gulp 任务 web

javascript - 在 Javascript 中对齐或填充这些字符串中的一些内容

javascript - 如何在angularjs上有多个$routeParams

javascript - 使用循环创建任务 [gulp]

node.js - Task Runner Explorer 窗口在我的 Gulpfile.js 下有 "failed to load"并且没有列出任何构建过程

Angularjs - Firefox 不会在新标签页中打开 blob url