javascript - 将控件添加到 ng-repeat 以过滤数据

标签 javascript json angularjs angularjs-ng-repeat angularjs-filter

我有一些用 ng-repeat 输出的 json 数据,我添加了一些表单控件来过滤来自另一个 json 的数据输出。

简化示例

第一个 JSON 数据:

var technologies = [
  {"id":"5", "slug":"mysql", "label":"MySQL", "category":"database"},
  {"id":"4", "slug":"html", "label":"HTML", "category":"markup"}
]

和输出:

<ul>
  <li ng-repeat="tech in technologies">
    <span>{{tech.label}}</span> 
    <span><label>required expertise 
      <select>
        <option>1</option>
        <option>2</option>
        <option>3</option>
        <option>4</option>
        <option>5</option>
      </select></label>
    </span>
  </li>
</ul>

(实际上,这些技术此时已经从用户在不同页面上做出的另一个选择中过滤出来,但我认为这没有区别)

第二个 json 包含我想用作过滤器的 expertise 属性

var people = [
{
  'label': 'MySQL',
  'slug': 'mysql',
  'talents':[
    {
      'name': 'Stanislav Lem',
      'expertise': 5,
      'desire': 0,
      'last_used': '2009-01'
    },
    {
      'name': 'Ijon Tichy',
      'expertise': 1,
      'desire': 5,
      'last_used': '2011-06'
    }
  ]
},  ...
]

...现在被简单地用作

<ul>
  <li ng-repeat="item in people">
    {{item.label}}<br>
    <ul>
      <li ng-repeat="person in item.talents">{{person.name}} &middot; Expertise: {{person.expertise}}</li>
    </ul>
  </li>
</ul>

我需要的是一个过滤器,它使用第一个输出中的选项来过滤第二个输出。例如,当 MySQL 所需的专业知识设置为“2”时,将仅显示 Stanislav Lem。实际上,如果没有人符合专业知识,我还需要一条“未找到结果”消息,但我想我可以自己解决这个问题。

Plunker 样本在这里:http://plnkr.co/edit/B0aQp9aCJ2g4OM6fZ3qe?p=preview

最佳答案

工作 Plunker:http://plnkr.co/edit/jcb6SfKVPkwt7FFCZFHX?p=preview

您需要做的第一件事是将 ng-model 属性添加到 select。我已将其添加为该技术的一个属性,因此您可以轻松找到它。

<select ng-model="tech.required">

接下来,我将以下两个函数添加到您的 Controller 以帮助过滤第二个列表:

$scope.getFilterForSlug = function(slug) {
    var technology = getTechBySlug(slug);

    return function(person) {
        return person.expertise >= (technology.required || 0);
    }
}

function getTechBySlug(slug) {
    return _.find($scope.technologies, {
        slug: slug
    });
}

正如名称所述,我在 getTechBySlug 中使用 lodash,以根据 slug 获取正确的技术对象。使用它,getFilterForSlug 返回一个函数,该函数将此人的专业知识水平与 select 中的期望水平进行比较。如果未选择某个选项,则所需级别设置为 0。

最后,在 HTML 中,我添加了以下内容:

<ul>
    <li ng-repeat="person in filteredPeople = (item.talents | filter: getFilterForSlug(item.slug))">{{person.name}} · Expertise: {{person.expertise}}</li>
</ul>
<span ng-if='!filteredPeople.length'>No Results!</span>

此代码根据当前 slug 获取过滤器,然后过滤使用该功能的人员。它将结果存储在变量 filteredPeople 中,该变量在 span 中用于在没有结果时显示消息。

关于javascript - 将控件添加到 ng-repeat 以过滤数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32981829/

相关文章:

c# - 如何在 web api 中重建返回类型对象

javascript - 我想在 Angularjs 表中显示此 Json 数据

javascript - 如何使用 http 响应填充作用域?

angularjs - 在多 View 路由器中解析 $http GET 请求(使用 ui.router)

javascript - 此示例中的 ng-show 不起作用

javascript - 对单个函数javascript的多个ajax调用

javascript - jQuery UI 对话框打开完成后删除过滤器属性

javascript - 如何从JS更改输入类型日期的最大值或最小值

javascript - HTML/PHP 页面中的 VBScript

javascript - 如何使用数据对象中的键设置 c3.js 图表数据类型?