javascript - 对象中嵌套数组的 Angular ng-repeat 过滤器

标签 javascript angularjs

我正在尝试基于嵌套数组在 ng-repeat 中应用过滤器。用于 ng-repeat 的对象:

已更新

主数组:

   {
  "0": {
    "Employee_Id": "hni",
    "comptencies": [
      {
        "Title": "Bunker Knowledge",
        "Level": 1
      },
      {
        "Title": "Bunker Knowledge",
        "Level": 3
      },
      {
        "Title": "IT Compliance",
        "Level": 2
      },
      {
        "Title": "Bunker Knowledge",
        "Level": 5
      }
    ],
  }
}

JS:

$scope.myFilter = {
    competencyTitle : ""
}

HTML:

<label>Competencies
<select ng-model="myFilter.competencyTitle" ng-options="item.Title for item in competencies_list"></select>
</label>


<tr ng-repeat="item in master_array | filter: { competencies: [{ Competency.Title: myFilter.competencyTitle }] }">

上面的方法不起作用。

案例

我有一个员工列表,每个员工都有一个 ID 和附加的能力数组。该数组中的每个项目都附加了一个能力数组,其中包含标题和能力的 ID。我想要的是能够过滤掉具有特定能力的员工。

有什么建议吗?

最佳答案

我找到了解决方案。您可能必须使其适应您的特定代码:

主要思想是这样的:filter: { $: {Title: myFilter.competencyTitle.Title} }

$ 选择其子级为 Title 的任何元素。

html

<label>Competencies {{myFilter.competencyTitle.Title}}
    <select ng-model="myFilter.competencyTitle" ng-options="item.Title for item in competencies_list"></select>
</label>


<p ng-repeat="item in master_array | filter: {  $: {Title: myFilter.competencyTitle.Title}  }">{{item.employee_id}} {{item.competencies}}    </p>

js - 这是使用的模型,我不确定这是否反射(reflect)了您的实际模型。

$scope.competencies_list = [{Title : "Math"},{Title : "English"},{Title : "Spanish"}];

$scope.master_array = 
[
    {         
        employee_id: "hni",         
        competencies:
            [
                {Title : "Math", "Level": 1},
                {Title : "English", "Level": 2}           
            ]
    }, 
    {
        employee_id: "xyz",         
        competencies:
            [
                {Title : "Spanish", "Level": 3},
                {Title : "English", "Level": 5}           
            ]
    }
];

$scope.myFilter = {
    competencyTitle : ""
};

关于javascript - 对象中嵌套数组的 Angular ng-repeat 过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35888267/

相关文章:

javascript - HTML CSS JS onload 更改图像大小比例错误

javascript - 我可以手动触发 ngMessages 验证吗?

angularjs - 禁用 angularjs 中的特定单个日期和多个日期(仅 datePicker 而不是 dateTimePicker)

angularjs - angularjs是否具有类似于jQuery的ajaxSetup的东西?

javascript - 我的用户可以通过单击缺少 Ajax 的按钮来访问 $_SESSION 的内容吗?

javascript - JQuery SlideToggle 和它下面的 DIV

javascript - document.querySelector返回null,但是元素存在

javascript - 如何正确更新IndexedDB中的文档?

javascript - 获取 Angular 选择中输入更改的当前文本

javascript - 如何使用 AngularJS 从自定义 URL 获取字体?