我在使用离子框架中的angularjs将数据绑定到我的视图时遇到了一些问题。
这是我的controller.js:
.controller('InventoryCtrl', function($scope, Category, Inventory) {
$scope.categories = Category;
$scope.searchInventory = function(category){
var word = category.Category;
var ref = new Firebase('https://vivid-heat-2430.firebaseio.com/');
var invenRef = ref.child('Inventories');
var prodRef = invenRef.child('Products');
invenRef.orderByChild("Products").on("child_added", function(snapshot) {
var data = snapshot.val();
var store = data.Inventory;
var prod = data.Products;
var test = Object.keys(prod);
for( var i = 0; i < test.length; i++){
if (test[i] == word) {
console.log(test[i]);
console.log("Storage place: " + data.Inventory + " Datum inventaris: " + data.Date);
$scope.show= test[i];
};
};
});
};
})
这里我从我的阵列中获取我的产品。然后我就比较了。它会给我匹配的对象,它也会给我它所属的存储位置。我可以在我的控制台中记录它。但是当我试图将它绑定到我的观点时。它什么都没给我。
这是我的index.html:
<ion-content>
<p><b>Zoek categorie</b></p>
<ion-scroll direction="y" >
<div style="max-height: 300px" ng-controller="InventoryCtrl">
<ion-list>
<ion-radio ng-repeat="category in categories" class="item-accordion" ng-model="checked.check" value="{{category.Category}}" ng-click="searchInventory(category)">
<p>{{category.Category}}</p>
</ion-radio>
<br>
</ion-list>
</div>
<div>
<ion-list>
<ion-item>
{{show}}
</ion-item>
</ion-list>
</div>
</ion-scroll>
</ion-content>
我不明白我做错了什么......是因为我的$scope.show
还在.on
方法中吗?
答案 0 :(得分:2)
并不熟悉Firebase,但我认为它是用于提取数据的第三方服务。可能是数据更新发生在角度摘要周期之外。只需在将数据附加到范围后添加它。
$ scope.digest()
答案 1 :(得分:0)
嘿,我猜你的类别依赖是一个注入你的控制器的服务?在这种情况下,我通常会写这样的东西。
.controller('InventoryCtrl', function($scope, Category, Inventory) {
$scope.categories = [];
Category.query(funciton(categories){
$scope.categories = angular.copy(categories);
});
在您在控制器中查询服务后,这将存储您的类别。之后,只需在你的html中使用像NG-REPEAT这样的东西。
<li ng-repeat='cat in categories'>
{{cat.name}}
{{cat.id}}
</li>
答案 2 :(得分:0)
@YerkenTussupekov关于第三方服务和摘要周期是正确的。
That's why at Firebase we created AngularFire.
AngularFire是一个Angular模块,为同步集合和身份验证提供一组服务。
angular.module('app', ['firebase']) // include it in the dep array
.constant('FirebaseUrl', '<my-firebase-app>') // https://vivid-heat-2430.firebaseio.com/ in your case
.service('rootRef', ['FirebaseUrl', Firebase)
.factory('categoryArray', CategoryArray)
.controller('MyCtrl', MyController);
function CategoryArray(rootRef, $firebaseArray) {
var invenRef = rootRef.child('Inventories');
return $firebaseArray(invenRef);
}
function MyController($scope, categoryArray) {
$scope.category = categoryArray;
}