我实际上是在尝试显示/隐藏部分的标题,基于也用于过滤ng-repeat
标题下方的点击事件。
ng-click
我的想法是通过重用我用于过滤器功能的类来切换一个类。我的过滤器在 ng-repeat 上工作得很好,但是我似乎无法让条件类在标题上工作。
以下是(简化的)代码:
<div ng-init="phones = [
{name:'Samsung Galaxy S II', product_type: 'android'},
{name:'iPhone 5', product_type: 'ios'},
{name:'Samsung Galaxy S II', product_type: 'android'},
{name:'iPhone 5', product_type: 'ios'},
{name:'Samsung Galaxy S II', product_type: 'android'},
{name:'iPhone 5', product_type: 'ios'}
]">
<!-- Filters for products -->
<a href="#" ng-click="property = null">All</a>
<a href="#" ng-click="property = {product_type:'android'}">Android</a>
<a href="#" ng-click="property = {product_type:'ios'}">iOS</a>
<!-- Android Product Section -->
<h2 ng-class="{true: 'hide', false: 'show'}[property == {product_type:'ios'}]">Android</h2>
<div ng-repeat="phone in phones | filter:property | filter:{product_type:'android'}">
<h3>{{ phone.name }}</h3>
</div>
<!-- iOS Product Section -->
<h2 ng-class="{true: 'hide', false: 'show'}[property == {product_type:'android'}]">iOS</h2>
<div ng-repeat="phone in phones | filter:property | filter:{product_type:'ios'}">
<h3>{{ phone.name }}</h3>
</div>
</div>
这是我的代码演示:http ://codepen.io/micjamking/pen/c0cfb8039492204d0282c42f563983e0
仅供参考,我无法更改上述 JSON(对象数组)的结构/方案。我实际上是从服务中的 API 获取数据,但认为这将是一种显示视图中正在发生的一切的简单方法。
我真诚地感谢任何人对此的帮助或建议。