无法绑定数据以查看angularjs

时间:2015-12-18 14:53:12

标签: javascript angularjs ionic firebase angularfire

我在使用离子框架中的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方法中吗?

3 个答案:

答案 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;
}