簡體   English   中英

如何使用數據庫中的對象數組作為過濾器?

[英]How can i use array of objects from database as filter?

 // filter with data from database not working app.filter('position', function($http, dbOperations) { console.log(dbOperations.getAccessPosition()); var positions = []; //[{name:"cashier",id:1},{name:"operator",id:2}]; // get the object array from database with name and id dbOperations.views("getPositions", "").then(function(res) { positions = res; // this is the desired value: [{name:"cashier",id:1},{name:"operator",id:2}] }); var poitionName = ""; return function(positionNum) { positions.forEach(function(p) { if (p.id == positionNum) { poitionName = p.name; return false; } }); return poitionName; } }); app.service('dbOperations', function($http) { this.getAccessPosition = function() { return $http({ method: "POST", url: "/common/functions.php", data: { 'process': "getAccessPosition", 'data': "" } }).then(function success(res) { return res; }, function myError(response) { // console.log("Error"); }); } }); 

當我console.log位置時,它會打印我需要的數據。 但過濾器不起作用。 可能是因為數據來自數據庫並且正在等待響應。 dbOperations是服務中的,我使用$ http。 請幫我解決一下這個。 謝謝。

在服務中,只需返回http請求,而不是解開promise。

app.service('dbOperations', function($http) {
  this.getAccessPosition = function() {
    return $http({
      method: "POST",
      url: "/common/functions.php",
      data: {
        'process': "getAccessPosition",
        'data': ""
      }
    })
  }
});

在過濾器中,在回調函數中進行服務調用。

app.filter('position', function($http, dbOperations) {
  console.log(dbOperations.getAccessPosition());
  var positions = []; //[{name:"cashier",id:1},{name:"operator",id:2}];

  var poitionName = "";
  return function(positionNum) {
    dbOperations.views("getPositions", "").then(function(res) {
      positions = res.data;
      positions.forEach(function(p) {
       if (p.id == positionNum) {
        poitionName = p.name;
        return false;
       }
      });
      return poitionName;
    });    
  }
});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM