我遇到了让我发疯的自定义指令问题。我正在尝试创建以下自定义(属性)指令:
angular.module('componentes', [])
    .directive("seatMap", function (){
        return {
            restrict: 'A',
            link: function(scope, element, attrs, controller){
                function updateSeatInfo(scope, element){
                    var txt = "";
                    for (var i in scope.seats)
                        txt = txt + scope.seats[i].id + " ";
                    $(element).text("seat ids: "+txt);
                }
                /* 
                    // This is working, but it's kind of dirty...
                    $timeout(function(){updateSeatInfo(scope,element);}, 1000);
                */
                scope.$watch('seats', function(newval, oldval){
                    console.log(newval, oldval);
                    updateSeatInfo(scope,element);
                });
            }
        }
    });
这个“属性类型”指令(称为 seatMap)试图显示一个座位 ID 列表(例如,对于剧院),我将通过 $resource 服务(参见下面的代码)从服务器获取到一个 div(元素) .
我将它与这个简单的部分 html 一起使用:
<div>
    <!-- This is actually working -->
    <ul>
        <li ng-repeat="seat in seats">{{seat.id}}</li>
    </ul>
    <!-- This is not... -->
    <div style="border: 1px dotted black" seat-map></div>
</div>
这是加载范围的控制器:
function SeatsCtrl($scope, Seats) {
    $scope.sessionId = "12345";
    $scope.zoneId = "A";
    $scope.seats = Seats.query({sessionId: $scope.sessionId, zoneId: $scope.zoneId});
    $scope.max_seats = 4;
}
其中“席位”是一个使用 $resources 从服务器获取 JSON 的简单服务
angular.module('myApp.services', ['ngResource'])
    .factory('Seats', function($resource){
        return $resource('json/seats-:sessionId-:zoneId.json', {}, {});
    })
;
app.js(asientos_libres.html 是我一直在使用的部分):
angular.module('myApp', ['myApp.filters', 'myApp.services', 'myApp.directives', 'componentes']).
  config(['$routeProvider', function($routeProvider) {
    $routeProvider.when('/view1', {templateUrl: 'partials/asientos_libres.html', controller: SeatsCtrl});
    $routeProvider.otherwise({redirectTo: '/view1'});
  }]);
问题是,即使我在指令的链接函数中设置了“scope.$watch”,以便范围可以检查“seats”属性是否已更改以更新 id 列表,但它在时刻 $scope.seats 在控制器中发生变化(当我们调用“查询”时)。
正如您在代码中看到的那样,我尝试使用 $timeout 来延迟“updateSeatInfo”的启动,但恐怕这不是迄今为止最聪明的解决方案......
我还尝试不发出 JSON 请求,而是在 $scope.seats 中使用硬编码字典并且它可以工作,所以这似乎是一个同步问题。
注意:updateSeatInfo 只是一个测试函数,我将使用的实际函数有点复杂。
关于如何应对它的任何想法?
非常感谢您!
编辑 1:添加了 app.js,我使用路由器调用 SeatsCtrl,感谢 Supr 的建议。但是,我仍然遇到同样的问题。
编辑2:解决了!(?) 好的!看来我找到了一个解决方案,它可能不是最好的,但它工作正常!:) 就我在这里看到的http://docs.angularjs.org/api/ng.$timeout而言,我们可以毫无延迟地使用 $timeout(setTimeout 的包装器)!这很好,因为我们没有在 $timeout 内人为地延迟代码的执行,而是让指令在异步请求完成之前不运行它。
希望它也适用于长时间等待的请求......
如果有人知道更好的解决方法,请告诉!