Заполнение данных с помощью Firebase и Angular
Я очень новичок в Firebase и во всем мире веб-разработки.
Я пытаюсь заполнить данные на моем веб-сайте данными из моей базы 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
1 ответ
Решение
У вас неправильное имя переменной в вашем шаблоне, это 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
переменная из контроллера $scope
и school
переменная создается в шаблоне.