2

私はrequirejsでangularAMDを使用しています.ng-tableモジュールをコントローラーに供給しようとすると、 Uncaught TypeError: Cannot read property 'module' of undefined from the ng-table module. が発生します。エラーの原因:

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

私のコードは次のとおりです。

'use strict';

requirejs.config({
  paths: {
    'angular': ['../lib/angularjs/angular'],
    'angular-route': ['../lib/angularjs/angular-route'],
    'angularAMD': ['../lib/angularAMD/angularAMD'],
    'ng-table': ['../lib/ng-table/ng-table']
  },
  shim: { 'angularAMD': ['angular'], 'angular-route': ['angular'], 'ng-table': ['angular']}
});


define(['angularAMD', 'angular-route'], function (angularAMD) {
    var app = angular.module("meadApp", ['ngRoute']);

    app.config(function ($routeProvider) {
        $routeProvider
            .when("/results", angularAMD.route({
                templateUrl: 'partials/results.html', controller: 'resultsController', controllerUrl: './controllers/resultsController'
            }))
            .otherwise({redirectTo: "/results"});
    });

    return angularAMD.bootstrap(app);
});

resultController.js

define(['app', 'ng-table'], function (app) {
    app.controller('resultsController', function ($scope, $http) {    
            $scope.users = [
                {name: "Moroni", age: 50},
                {name: "Tiancum", age: 43},
                {name: "Jacob", age: 27},
                {name: "Nephi", age: 29},
                {name: "Enos", age: 34}
            ];    
    });
});

results.html

<div>
    <table ng-table class="table">
        <tr ng-repeat="user in users">
            <td data-title="'Name'">{{user.name}}</td>
            <td data-title="'Age'">{{user.age}}</td>
        </tr>
    </table>
</div>
4

3 に答える 3

2

angular の shim を作成し、 angular をエクスポートします。このような:

main.js:

requirejs.config({
  paths: {
    'angular': ['../lib/angularjs/angular'],
    'angular-route': ['../lib/angularjs/angular-route'],
    'angularAMD': ['../lib/angularAMD/angularAMD'],
    'ng-table': ['../lib/ng-table/ng-table']
  },
  shim: {
    'angular': { exports: 'angular' },
    'angularAMD': ['angular'],
    'angular-route': ['angular'],
    'ng-table': ['angular']}
});

ここからこれを見つけました:https://github.com/esvit/ng-table/pull/377#issuecomment-57934733


@marcoseuの答えはうまくいきませんでした。私はngloadRestangular も必要ないことがわかりました.Restangular は、angular がブートストラップされた後にロードされる別のサードパーティの angular モジュールです。それがどうしたのかわからない、理解できないはずだ。

于 2015-06-11T08:16:42.497 に答える
1

既存の angular モジュールのロードは、 を使用して行う必要がありますngloadngloadあなたに追加main.js

requirejs.config({
  paths: {
    'ngload': ['../lib/angularAMD/ngload'],
    ...
  },
  shim: { 'ngload': ['angularAMD'], ...}
});

次に、それを使用して以下をロードしますng-table

define(['app', 'ngload!ng-table'], function (app) {
    app.controller('resultsController', function ($scope, $http) {    
            $scope.users = [
                {name: "Moroni", age: 50},
                {name: "Tiancum", age: 43},
                {name: "Jacob", age: 27},
                {name: "Nephi", age: 29},
                {name: "Enos", age: 34}
            ];    
    });
});

詳細については、サードパーティの AngularJS モジュールを参照してください。

于 2015-04-26T13:00:42.140 に答える