用Firebase和Angular填充数据表

populating datatable with Firebase and Angular

本文关键字:填充 数据表 Angular Firebase      更新时间:2023-09-26

我对Firebase和整个web开发技巧都很陌生。

我正在尝试用我的Firebase中的数据填充我的网站中的数据表。

这是引导中的数据表

以下是app.js

var app = angular.module("aocgApp", ["firebase"]);
app.controller("dataController", ["$scope", "$firebaseArray", 
function($scope, $firebaseArray) {
    var national = new Firebase("https://aoconsultinggroup.firebaseio.com/National");
    $scope.schools = $firebaseArray(national);
}]);

最后,html代码:

<div class="panel-body">
<div ng-app="aocgApp" ng-controller="dataController">
<div class="table-responsive">
    <table class="table">
        <thead>
            <tr>
                <th>School Name</th>
                <th>SATs</th>
                <th>GPA</th>
                <th>Tuition</th>
            </tr>
        </thead>
        <tbody>
            <tr ng-repeat="school in schools">
                <td>{{ schools.name }}</td>
                <td>{{ schools.sat24l }}</td>
                <td>{{ schools.gpa }}</td>
                <td>{{ schools.tuition }}</td>
            </tr>
        </tbody>
    </table>
</div>
</div>
</div>

谢谢你的帮助。

编辑:以下是的数据结构

 aoconsultinggroup
  L Business
  L CS
  L Engineering
  L National
    L 0
       L name
       L SAT
       L GPA
       L tuition
    L 1
       L name
       L SAT
       L GPA
       L tuition
    L 2
       L name
       L SAT
       L GPA
       L tuition
    L 3
       L name
       L SAT
       L GPA
       L tuition

您的模板中有错误的变量名,它是schools而不是national:

<tr ng-repeat="school in schools">
  <td>{{ school.name }}</td>
  <td>{{ school.sat24l }}</td>
  <td>{{ school.gpa }}</td>
  <td>{{ school.tuition }}</td>
</tr>

在控制器中,您不需要使用$loaded()。数据下载后,$firebaseArray()将触发$digest循环。

你只需要这个:

var national = new Firebase("<your-firebase-app>/National");
$scope.schools = $firebaseArray(national);

这就是school in schools在模板中工作的原因。schools变量来自控制器的$scopeschool变量在模板中创建。