Обнулить объектную ошибку в Chrome. Angularjs + ngResource
При использовании отладки в Chrome он продолжает показывать эту ошибку: неперехваченный объект, на angular.js: 36.
Что я делаю неправильно?:/
Спасибо за любую помощь:)
Объекты Module и Resource (services.js)
var services = angular.module('ngdemo.services', ['ngResource']);
services.factory('ProvidersFactory', function ($resource) {
return $resource('http://devfz.azurewebsites.net/api/providers/', {}, {
query: { method: 'GET', isArray: true },
})
});
Контроллер (controller.js)
var app = angular.module('ngdemo.controllers', []);
app.controller('ProviderListCtrl', ['$scope', 'ProvidersFactory', '$location',
function ($scope, ProvidersFactory, $location) {
$scope.providers = ProvidersFactory.query();
}]);
app.js
angular.module('ngdemo', ['ngdemo.filters', 'ngdemo.services', 'ngdemo.directives', 'ngdemo.controllers']).
config(['$routeProvider', function ($routeProvider) {
$routeProvider.when('/provider-list', { templateUrl: '/provider-list.html', controller: 'ProviderListCtrl' });
$routeProvider.otherwise({ redirectTo: '/provider-list' });
}]);
HTML
<!DOCTYPE html>
<html ng-app="ngdemo" xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Providers</title>
<link href="Content/bootstrap.min.css" rel="stylesheet">
<script src="Scripts/Vendor/angular.min.js"></script>
<script src="Scripts/Vendor/angular-resource.js"></script>
<script src="controller.js"></script>
<script src="services.js"></script>
<script src="app.js"></script>
</head>
<body role="document" style="padding-top: 70px; padding-bottom: 30px">
<div class="container body-content" role="main">
<div ng-controller="ProviderListCtrl">
<h2>Providers</h2>
<hr>
<div style="width:60%">
<table class="table table-striped table-condensed">
<thead>
<tr>
<th style="min-width: 30px; width: 30px;">Id</th>
<th style="min-width: 100px;">Name</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="provider in providers">
<td valign="middle">Test: {{provider.Id}}</td>
<td valign="middle">Test: {{provider.Name}}</tdvalign>
<td valign="middle" align="right" width="40px"><a ng-click="" class="btn btn-small btn-primary">edit</a></td>
<td valign="middle" align="right" width="50px"><a ng-click="" class="btn btn-small btn-danger">delete</a></td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</body>
</html>
Ответы
Ответ 1
Попробуйте отладить в браузере Safari
. Для меня он получает больше информации об этой ошибке. В моем случае я использую приложение angular-seed
и переименую ' myApp' в ' myNameOfAppApp.
Я получил эту ошибку в Safari
:
Ошибка: [$ injector: modulerr] Не удалось создать модуль myApp из-за: [$ injector: nomod] Модуль 'myApp' недоступен! Вы либо с ошибкой написало имя модуля или забыло загрузить его. Если вы регистрируете модуль гарантирует, что вы укажете зависимости как второй аргумент.
Я пытаюсь найти ключевое слово mayApp и после переименования в index.html Исправлена ошибка.
Ответ 2
Чтобы использовать $routeProvider
, вам нужно включить (и объявить как зависимость) модуль ngRoute
.
Смотрите, этот ответ для получения дополнительной информации.