Как отфильтровать массив с помощью arraylist с помощью ng-repeat - PullRequest
0 голосов
/ 20 мая 2018

Я пытаюсь отфильтровать массив с помощью простого списка массивов, но не могу понять, как, я пытался использовать пользовательский фильтр, но не могу заставить его работать.Изменить: я добавил больше кода.Текстовое поле Поиск работает нормально, но когда я добавляю myFilterby в ng-repeat, он больше не фильтруется.Я просто хочу отфильтровать список массивов.

<div class="input-group">
    <input type="text" class="form-control" placeholder="Search .." ng-model="searchText">
    <span class="input-group-btn">
      <button class="btn btn-default" type="button">
        <span class="glyphicon glyphicon-search"></span>
      </button>
    </span>
</div>
</div>

<td ng-repeat="a in product| filter:searchText | filter:myFilterBy">
    <img class="avatar" src="img/{{a.image}}" alt="">
    <div class="middleT">
        <p>{{a.brand}} {{a.model}} </p>
        <p>${{a.price}} </p>
    </div>

Угловой:

var HandleModule = angular.module("HandleModule",['rzModule','ui.bootstrap','angular.filter']);
HandleModule.controller('HandleCtrl',function($scope,$http){
    // get data from the server in JSON format
   $scope.chk0 = ['apple', 'orange', 'banana'];
    $http.get('./loader.php').then(successCallback, errorCallback);
    function successCallback(response){
    //success code
    $scope.product = response.data;
    }
    function errorCallback(error){
    //error code
    $scope.product="error";
    }


$scope.myFilterBy = function(e) {
    return $scope.chk0.indexOf(e) !== -1;
}

PHP:

 <?php
$con = mysqli_connect("localhost","root","","product");
$query = "SELECT id, model, brand, price, description, image,  FROM fruits ORDER BY id";
  $result = mysqli_query($con, $query);
$fruits= array();
while($row = mysqli_fetch_assoc($result))
 {
$fruits[] = $row;
 }
echo json_encode($fruits);


?>

Использовал NG-повтор для распечатки данных отдельно.Я использовал ng-repeat для отображения на html

  <p ng-repeat="a in products ">
  {{a}}
{"id":"1","model":"test1","brand":"orange","price":"4",
 "description":"orange sweet and sour","image":"orange.jpg"}

{"id":"2","model":"test2","brand":"banana","price":"3",
 "description":"yellow sweet","image":"banana.jpg"}

{"id":"3","model":"test3","brand":"apple","price":"5",
 "description":" red sweet crunchy","image":"apple.jpg"}

1 Ответ

0 голосов
/ 21 мая 2018

Из того, что я могу расшифровать из вашего вопроса и последующих комментариев, вы просто пытаетесь отфильтровать массив продуктов по поисковому тексту, введенному пользователем, и статический массив.

Ваша проблема в том, что выпытаясь сравнить объект с массивом строк.Чтобы решить вашу проблему, вы должны сравнить свойство объекта, в данном случае бренд, с массивом строк.

Вы можете увидеть, как оно работает ниже.Для простоты я удалил любой код, который не был необходим для этой проблемы.

var HandleModule = angular.module("HandleModule", []);
HandleModule.controller('HandleCtrl', function($scope) {
  $scope.chk0 = ['apple', 'orange', 'banana'];

  $scope.product = [{
    "id": "1",
    "model": "test1",
    "brand": "orange",
    "price": "4",
    "description": "orange sweet and sour",
    "image": "orange.jpg"
  }, {
    "id": "2",
    "model": "test2",
    "brand": "banana",
    "price": "3",
    "description": "yellow sweet",
    "image": "banana.jpg"
  }, {
    "id": "3",
    "model": "test3",
    "brand": "apple",
    "price": "5",
    "description": "red sweet crunchy",
    "image": "apple.jpg"
  }, {
    "id": "4",
    "model": "test4",
    "brand": "pear",
    "price": "6",
    "description": "red sweet crunchy",
    "image": "pear.jpg"
  }];

  $scope.myFilterBy = function(e) {
    return $scope.chk0.indexOf(e.brand) >= 0;
  };
});
<html ng-app="HandleModule">

<head>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
</head>

<body ng-controller="HandleCtrl">
  <div class="input-group">
    <input type="text" class="form-control" placeholder="Search .." ng-model="searchText" />
  </div>
  <table>
    <tbody>
      <tr>
        <td ng-repeat="a in product| filter:searchText | filter:myFilterBy">
          <div>
            <p>{{a.brand}} {{a.model}} </p>
            <p>${{a.price}} </p>
          </div>
        </td>
      </tr>
    </tbody>
  </table>
</body>

</html>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...