2016-03-11 70 views
1

我已經成功將我的Firebase綁定到Google Charts上,效果很好,但我在如何顯示一條簡單的消息,指出「無數據」沒有數據可以評估爲我聲明的簡單的if else表達式。當Firebase數據發生變化時,Google Charts不會得到更新

例如,我爲單個用戶設置了「不適用」的Firebase數據值,理論上這意味着圖表不會默認顯示,並且錯誤消息會在頁面加載和任意點顯示這會變回這個值。但是,情況並非如此,觸發它的唯一方法是單擊我在HTML文件中設置的3D按鈕。此外,當Firebase數據更改爲大於零的值時,仍會顯示錯誤消息。

這裏是我的代碼:

JS文件

var displayMode = true; 

$scope.statistics = function() { 
    $mdSidenav('left').close(); 
    $state.go('statistics'); 
    $timeout(function() { 
     setUpChart(); 
     var timer; 
     $(window).on('resize', function() { 
      clearTimeout(timer); 
      timer = setTimeout(function() { 
       setUpChart(); 
      }, 250); 
     }); 
    }); 
}; 

function setUpChart() { 

    $.ajax({ 
     url: '//www.google.com/jsapi', 
     dataType: 'script', 
     cache: true, 
     success: function() { 
      google.load('visualization', '1', { 
       'packages': ['corechart'], 
       'callback': drawChart 
      }); 
     } 
    }); 

    function drawChart() { 

     // This links to my Firebase url 
     userRef.on('value', function (snapshot) { 

      var pass = 0; 
      var fail = 0; 

      snapshot.forEach(function (snapshot) { 
       var userResults = snapshot.val(); 
       if (userResults.passFail === 'Pass') { 
        pass = pass + 1; 
       } 
       if (userResults.passFail === 'Fail') { 
        fail = fail + 1; 
       } 
      }); 

      if (pass === 0 && fail === 0) { 
       console.log('No data: ' + pass + ' & ' + fail); 
       $scope.error = true; 
       $scope.errorMessage = 'No user data available, please try 
       again later.'; 
      } else { 
       console.log('Is data: ' + pass + ' & ' + fail); 
       $scope.error = false; 
       $scope.errorMessage = null; 
       var data = new google.visualization.DataTable(); 
       data.addColumn('string', 'Result'); 
       data.addColumn('number', 'Delegates'); 
       data.addRows([ 
        ['Pass', pass], 
        ['Fail', fail] 
       ]); 

       var options = { 
        'is3D': displayMode, 
        'chartArea': {'width': '100%', 'height': '80%'}, 
        'legend': {'position': 'top', 'alignment': 'center'} 
       }; 

       var chart = new 
     google.visualization.PieChart(document.getElementById('pieChart')); 
       chart.draw(data, options); 
      } 

     }); 

    } 

} 

// Changes chart type to 3D or top view on a butto click 
$scope.chartFormat = function() { 
    if (displayMode == true) 
     displayMode = false; 
    else 
     displayMode = true; 
    setUpChart(); 
}; 

HTML

<div class="container" style="padding-top: 100px; padding-bottom: 50px"> 

<button data-ng-model="displayType" style="display: block; margin: 0 auto" 
     data-ng-click="displayType=displayType ? false : true; 
     chartFormat()" 
     class="btn btn-default btn-md" type="button"><i class="material- 
     icons">3d_rotation</i></button> 

<div data-ng-if="error" class="alert alert-danger"> 
    <span data-ng-if="errorMessage" class="glyphicon glyphicon-remove"> 
    </span><strong> {{errorMessage}}</strong> 
</div> 

<div id="pieChart" style="display: block; margin: 0 
auto; width: 100%; height: 500px"></div> 

</div> 
+0

請注意,更新作用域的角度核心外部的代碼需要通知角度來運行摘要。 – charlietfl

+0

可以請你解釋一下,因爲我之前沒有使用過這個方法嗎? –

+0

使用'$ scope。$ apply()' – charlietfl

回答

0

你在userRef.on('value', function (snapshot) {運行代碼以異步每當火力地堡的數據發生變化。在那一刻AngularJS不期望修改$scope,所以它沒有看到它們。

的解決方案是讓AngularJS知道你通過調用$scope.$apply()作爲charlieftl建議或通過在$timeout()以便它能夠在未來消化週期拿起包裹它改變了$scope的事實:

userRef.on('value', function (snapshot) { 
    $timeout(function() { 
     var pass = 0; 
     var fail = 0; 

     snapshot.forEach(function (snapshot) { 
      var userResults = snapshot.val(); 
      if (userResults.passFail === 'Pass') { 
       pass = pass + 1; 
      } 
      if (userResults.passFail === 'Fail') { 
       fail = fail + 1; 
      } 
     }); 

     if (pass === 0 && fail === 0) { 
      console.log('No data: ' + pass + ' & ' + fail); 
      $scope.error = true; 
      $scope.errorMessage = 'No user data available, please try 
      again later.'; 
     } else { 
      console.log('Is data: ' + pass + ' & ' + fail); 
      $scope.error = false; 
      $scope.errorMessage = null; 
      var data = new google.visualization.DataTable(); 
      data.addColumn('string', 'Result'); 
      data.addColumn('number', 'Delegates'); 
      data.addRows([ 
       ['Pass', pass], 
       ['Fail', fail] 
      ]); 

      var options = { 
       'is3D': displayMode, 
       'chartArea': {'width': '100%', 'height': '80%'}, 
       'legend': {'position': 'top', 'alignment': 'center'} 
      }; 

      var chart = new 
    google.visualization.PieChart(document.getElementById('pieChart')); 
      chart.draw(data, options); 
     } 

    }); 

}); 
+0

嗨,弗蘭克,謝謝你的迴應。我以前嘗試過這種方法,並且只是再次嘗試,看它是否會起作用。但是,它將錯誤提示爲'錯誤:容器未定義',以下代碼引用Pp @ https://www.google.com/uds/api/visualization ... –

+0

忽略我以前的評論,我曾一個'data-ng-if'在我的html中用於餅圖,現在我已經刪除了它。但是,它仍然無法顯示錯誤消息。首頁加載時只有這種情況,它應該顯示消息。例如,如果我手動將Firebase數據值更改爲「Pass」,則它將全部開始按照我的要求工作 –

0

如果有人遇到上述類似的問題,只需將data-ng-init =「function_name_here()」添加到要在HTML中顯示的錯誤消息div中,如果Google Chart沒有數據。

從來沒有想過這個,但現在工作治療,並動態顯示錯誤信息在我的情況下,並刪除消息,如果數據存在!

相關問題