3

我正在尝试使用运行 webpack 的Laravel Mix将 Angular 应用程序编译到一个文件中。我得到错误:

未捕获的 ReferenceError:未定义应用程序

我的webpack.mix.js

const { mix } = require('laravel-mix');

mix.js('resources/assets/js/dependencies.js', 'public/js')
   .sass('resources/assets/sass/app.scss', 'public/css');

我的bundle.js

//load angular
require('angular');

//Load Angular's plugins
require('angular-ui-router');

//Init Angular app
require('./app/app');

//Load angular controllers
require('./app/Controller/aboutController');
....

//Load angular directive
require('./app/Directive/directive');

//Load angular services
require('./app/Services/AccountService');
....

我的app/app.js

var app = angular.module('app', ['ui.router']);

app.config(['$stateProvider', '$urlRouterProvider', '$locationProvider', function ($stateProvider, $urlRouterProvider, $locationProvider) {

$urlRouterProvider.otherwise('/home');

$stateProvider
    .state('home', {
        url: '/home',
        templateUrl: 'app/View/homeView.html',
        controller: 'homeController'
    })
    ...
}]);


app.run(['$state', '$rootScope', function ($state, $rootScope) {
    //APP RUN
}]);

Uncaught ReferenceError: app is not defined 当我打电话时,我得到了app.controller(),例如app/Controller/aboutController.js

app.controller("aboutController", ['$scope', '$rootScope', '$http', function ($scope, $rootScope, $http) {....}

我错过了什么吗?如果我使用它一一加载所有文件,html它工作正常。

4

2 回答 2

3

如果您在单独的文件中定义应用程序的控制器,那么您不能直接使用应用程序,因为没有参考。您首先必须参考模块。

angular.module('app')
  .controller('aboutController'....

让我知道这是否适合您。

于 2017-02-27T11:23:55.657 回答
0

对于希望在下一个 Laravel 项目中以更自动化的方式执行此操作的任何人,我创建了一篇文章来解释如何。在 Angular 版本 4-7 和 Laravel 版本 5.4-5.8 上测试。我希望它有帮助!

于 2019-04-23T02:48:10.693 回答