我已经看到了这个问题,但是,我对我有些困惑。解决方案指出要删除其中一个控制器。因此,当我从body标签中删除ng-controller = sigSearchResults时,我的结果不会填充在ng-grid =“ gridOptions”中。如何纠正呢?
var sig = angular.module('sig', ['ngRoute']);
sig.config([ '$routeProvider', function($routeProvider) {
$routeProvider.when('/search/:sig', {
template : ' ',
controller : 'sigSearchResults'
}).when('/', {
template : ' ',
controller : 'sigSearchResults'
}).otherwise({
redirectTo : '/'
});
} ]);
sig.controller('sigSearchResults', function($scope,$log,$http,$q,$routeParams, $window) {
console.log($routeParams);
//code that populates ng-grid to gridOptions element.
});
<html ng-app="sig">
<body ng-controller="sigSearchResults">
<div class="contentContainer">
<div ng-view></div>
<!-- This is the template for the result -->
<script type="text/ng-template" id="sig-search-result-id" >
<div ng-show="loading" style='clear:both; text-align: center;'>Loading report...<img src="../media/images/Wait3.gif"></div>
<div ng-show="!loading" class="gridStyle" ng-grid="gridOptions"></div>
</script>
</div>
最佳答案
是的,因为您正在使用ng-controller="sigSearchResults"
配置路由和视图,所以从<body>
标记中删除了$routeProvider
,并且看起来控制器不应该在顶层运行。
看起来您所缺少的只是您的路由配置中的tempateUrl
,即
when('/', {
templateUrl: 'sig-search-result-id',
controller: 'sigSearchResults'
})
关于javascript - Angular Controller 被调用两次,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25540879/