angularjs在后端更改时自动重新加载

时间:2015-10-22 03:45:41

标签: angularjs rest frontend backend

我的应用程序需要在后端更改时自动刷新。我添加了一个按钮来重新加载GET到我的后端,但我不希望这样做。这是我的代码

<body data-ng-app="myPr">
  <div ng-controller="TodosController">
    <div ng-repeat="todo in todos">
      <p>{{todo.title}} ...... {{todo.is_completed}}</p>
    </div>
    <button ng-click="reload()">Reload</button>
  </div>
</body>

我的app.js

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

myPr.controller("TodosController", function ($scope,$http){

  $scope.reload = function () {
    $http.get('http://localhost:3000/api/todos').
        success(function (data) {
          $scope.todos = data.todos;
      });
  };
  $scope.reload();
});

由于

2 个答案:

答案 0 :(得分:15)

您可以定期重新加载数据。否则,您需要设置socket.ioPusher之类的内容,并在服务器更新时将通知推送到浏览器。

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

myPr.controller("TodosController", function ($scope,$http,$timeout){

  $scope.reload = function () {
    $http.get('http://localhost:3000/api/todos').
        success(function (data) {
          $scope.todos = data.todos;
      });

    $timeout(function(){
      $scope.reload();
    },30000)
  };
  $scope.reload();
});

答案 1 :(得分:12)

您可以使用$interval(fuctionToRepeat, intervalInMillisecond)作为记录here

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

myPr.controller("TodosController", function ($scope,$http){

    $scope.reload = function () {
        $http.get('http://localhost:3000/api/todos').
            success(function (data) {
                $scope.todos = data.todos;
            });
    };
    $scope.reload();
    $interval($scope.reload, 5000);
});
  

注意:完成后,必须明确销毁此服务创建的间隔。特别是当控制器的范围或指令的元素被破坏时,它们不会被自动销毁。你应该考虑到这一点,并确保在适当的时候总是取消间隔。