Nano Hash - криптовалюты, майнинг, программирование

AngularJS: фильтр по полю объекта внутреннего массива

У меня есть следующие данные:

organizations:[{
                name: "foo",
                contacts: [{
                             firstName = "John",
                             lastName = "Doe",
                             email = "[email protected]"
                          },...]
               },...]

Затем у меня есть таблица, в которой я перечисляю все организации, и я хочу знать, можно ли фильтровать строки в таблице в соответствии с фильтром firstName или фильтром электронной почты.

Например, у меня есть этот код:

<input type="text" id="name" ng-model="search.name">

<tr ng-repeat="organization in organizations | filter:search">
    <td>{{organization.name}}</td>
    <td>{{client.contacts[0].firstName}} {{ client.contacts[0].lastName }}</td>
    <td>{{client.contacts[0].email}}</td>
</tr>

Работает фильтрация только по полю 'имя'. Я пробовал что-то вроде этого:

<input type="text" id="firstName" ng-model="search.contacts">

Но он ищет по всем полям объектов в массиве контактов, а я хочу конкретно искать по firstName. Как я могу сделать?

19.07.2013

  • Вы пробовали ‹input type=text id=firstName ng-model=search.contacts.firstName› 19.07.2013
  • Я пробовал, но не работает, я думаю, потому что контакты - это массив. 19.07.2013

Ответы:


1

Используйте функцию фильтра, например filter:filterBy.

Пример (зависит от underscore.js):

scope.filterBy = function(row) {
    return !!_.where(row.contacts, {firstName:scope.search.name}).length;
}
19.07.2013
  • Одна вещь, которую следует отметить в отношении фильтров, заключается в том, что они должны быть быстрыми. Если по какой-либо причине вы видите, что фильтры замедляют работу, попробуйте $просмотреть свойства фильтра, затем вручную отфильтровать свой массив и в шаблоне ng-repeat по отфильтрованному массиву. 19.07.2013
  • Действительно @LiviuT. Для небольшого количества строк подойдет фильтр. 19.07.2013
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..