ajax post 请求后范围变量未更改

Scope variable not changing after ajax post request

我正在制作 Yahtzee SPA。这是我的 js 文件

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

game.controller('RollDicesController', function($scope, $http) {
  $scope.img1 = "style/img/dice1.jpg";
  $scope.img2 = "style/img/dice2.jpg";
  $scope.img3 = "style/img/dice3.jpg";
  $scope.img4 = "style/img/dice4.jpg";
  $scope.img5 = "style/img/dice5.jpg"; 

 $scope.result = {
     Ones : '0',
     Twos : '0',
     Threes : '0',
     Fours : '0',
     Fives : '0',
     Sixes : '0',
     ThreeOfAKind : '0',
     FourOfAKind : '0',
     FullHouse : '0',
     SmallStraight : '0',
     LargeStraight : '0',
     Chance: '0',
     Yahtzee : '0'
 };

 $scope.notSorted = function(obj){
     if (!obj) {
         return [];
     }
     return Object.keys(obj);
 }

 $scope.rollDices = function() {
     $dice1 = Math.floor((Math.random() * 6) + 1);
     $dice2 = Math.floor((Math.random() * 6) + 1);
     $dice3 = Math.floor((Math.random() * 6) + 1);
     $dice4 = Math.floor((Math.random() * 6) + 1);
     $dice5 = Math.floor((Math.random() * 6) + 1);

     $scope.img1 = "style/img/dice" + $dice1 + ".jpg";
     $scope.img2 = "style/img/dice" + $dice2 + ".jpg";
     $scope.img3 = "style/img/dice" + $dice3 + ".jpg";
     $scope.img4 = "style/img/dice" + $dice4 + ".jpg";
     $scope.img5 = "style/img/dice" + $dice5 + ".jpg";

     $http.post('calculate', {'dice1': $dice1, 'dice2': $dice2, 'dice3': $dice3, 'dice4': $dice4, 'dice5': $dice5 }).success(function(data) {
         $scope.result = data;
     }).error(function(data, status) { 
         $scope.errors.push(status);
     });

  };

});

请求所做的几乎是相应动作的属性值。我有一个 php 控制器连接到 calculate 路由(我使用的是 Laravel),它完成所有的数学工作。 现在的问题是,尽管我正确地接收到这些值(我已经测试过了),但我的 table 没有更新。

我的网页中已经有一个主 div 定义了控制器:

<div ng-controller="RollDicesController">
    <div id="game_div">
        <div id="dice_div">
            <ul>
              <li style="list-style-type: none;" class="listaDados"  >
               <img id="dice1" ng-src="{{img1}}">
               <img id="dice2" ng-src="{{img2}}" > 
               <img id="dice3" ng-src="{{img3}}" > 
               <img id="dice4" ng-src="{{img4}}" >
               <img id="dice5" ng-src="{{img5}}" > 
              </li>
            </ul>
            <a>  
                <button id="rolldice_button" class= "button_class" ng-click="rollDices()">
                    Roll Dice!
                </button>
            </a>  
    <div id="table_div">
        <table id="score_table" border="1" >
            <tr ng-repeat="key in notSorted(result) track by $index" ng-init="val = result[key]">
                <td> {{ key }} </td>
                <td> {{ val }} </td>
            </tr>
        </table>
    </div>
</div>

出于某种原因,table 永远不会改变,尽管 $scope.result 和骰子图像会改变。

我真的不明白我做错了什么,所以我需要你的帮助。

编辑 1:删除后我发现:

     $scope.result = {
     Ones : '0',
     Twos : '0',
     Threes : '0',
     Fours : '0',
     Fives : '0',
     Sixes : '0',
     ThreeOfAKind : '0',
     FourOfAKind : '0',
     FullHouse : '0',
     SmallStraight : '0',
     LargeStraight : '0',
     Chance: '0',
     Yahtzee : '0'
 };

我按下按钮,它起作用了一次,接下来的点击并没有改变 table。 由于某种原因,在我给 $scope.result 一个值之后,它的值再也不会改变了。由于我对 AngularJS 的了解有限,我不知道为什么会这样

编辑 2:我试过使用 $scope.apply() 更改请求,像这样

$http.post('calculate', {'dice1': $dice1, 'dice2': $dice2, 'dice3': $dice3, 'dice4': $dice4, 'dice5': $dice5 }).success(function(data) {
            $scope.result = data;
            $scope.apply();
    }).error(function(data, status) { 
        $scope.errors.push(status);
    });

编辑 3:$scope.$apply 在我之前的编辑中写得不好,在更正后,它现在向我显示此错误

Error: error:inprog Action Already In Progress $digest already in progress

最终编辑:$timeout 有效,问题是使用 notSorted 函数。

table现在是这样创建的:

        <div id="table_div">
        <table id="score_table" border="1" >
            <tr ng-repeat="(key, val) in result track by $index">
                <td> {{ key }} </td>
                <td> {{ val }} </td>
            </tr>
        </table>
    </div>

虽然它没有按照我想要的方式排序,但至少它是有效的。

试试这个,建议不要使用 $apply。

注意我在顶部注入了 $timeout。

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

game.controller('RollDicesController', function($scope, $http, $timeout) {
  $scope.img1 = "style/img/dice1.jpg";
  $scope.img2 = "style/img/dice2.jpg";
  $scope.img3 = "style/img/dice3.jpg";
  $scope.img4 = "style/img/dice4.jpg";
  $scope.img5 = "style/img/dice5.jpg"; 

 $scope.result = {
     Ones : '0',
     Twos : '0',
     Threes : '0',
     Fours : '0',
     Fives : '0',
     Sixes : '0',
     ThreeOfAKind : '0',
     FourOfAKind : '0',
     FullHouse : '0',
     SmallStraight : '0',
     LargeStraight : '0',
     Chance: '0',
     Yahtzee : '0'
 };

 $scope.notSorted = function(obj){
     if (!obj) {
         return [];
     }
     return Object.keys(obj);
 }

 $scope.rollDices = function() {
     $dice1 = Math.floor((Math.random() * 6) + 1);
     $dice2 = Math.floor((Math.random() * 6) + 1);
     $dice3 = Math.floor((Math.random() * 6) + 1);
     $dice4 = Math.floor((Math.random() * 6) + 1);
     $dice5 = Math.floor((Math.random() * 6) + 1);

     $scope.img1 = "style/img/dice" + $dice1 + ".jpg";
     $scope.img2 = "style/img/dice" + $dice2 + ".jpg";
     $scope.img3 = "style/img/dice" + $dice3 + ".jpg";
     $scope.img4 = "style/img/dice" + $dice4 + ".jpg";
     $scope.img5 = "style/img/dice" + $dice5 + ".jpg";

     $http.post('calculate', {'dice1': $dice1, 'dice2': $dice2, 'dice3': $dice3, 'dice4': $dice4, 'dice5': $dice5 }).success(function(data) {
         $timeout(function() {
             $scope.result = data;
         });
     }).error(function(data, status) { 
         $scope.errors.push(status);
     });

  };

});

试试下面的代码:

<div id="table_div">
        <table id="score_table" border="1" >
            <tr ng-repeat="key in result track by $index" ng-init="val = result[key]">
                <td> {{ key }} </td>
                <td> {{ val }} </td>
            </tr>
        </table>
</div>

或者试试这个:

$http.post('calculate', {'dice1': $dice1, 'dice2': $dice2, 'dice3': $dice3, 'dice4': $dice4, 'dice5': $dice5 }).success(function(data) {
         $timeout(function() {
             $scope.result = data;
         });
     }).error(function(data, status) { 
         $scope.errors.push(status);
     });
$timeout to avoid $digest error.