【发布时间】:2015-07-02 19:51:20
【问题描述】:
假设我有类似的东西:
<md-grid-tile class="gray" ng-repeat="carto in cartoList" ng-if="search(carto)">
<md-button ng-click="changeSVG(carto.fileName)" aria-label="carto.displayName">
<img src="style/images/thumbnails/{{carto.fileName}}.png" width="100%" height="100%" title="{{carto.fullDisplayName}}" style="max-height: 220px;"></img>
</md-button>
<md-grid-tile-footer><h3 align="center">{{carto.displayName}}</h3> </md-grid-tile-footer>
</md-grid-tile>
有没有办法检索显示的瓷砖数量?表示ng-repeat 中与ng-if 匹配的元素数量:
<md-grid-tile class="gray" ng-repeat="carto in cartoList" ng-if="search(carto)">
根据要求,search 函数:
$scope.search = function (carto) {
if ($scope.sideMenu) {
var searchRegex = new RegExp('global', 'i');
if (carto.fullDisplayName.search(searchRegex) != -1)
return true;
}
else if ($scope.sideSearch) {
if ($scope.searched.IS.indexOf(carto.informationSystem) === -1 && carto.informationSystem)
return false;
if ($scope.searched.area.indexOf(carto.area) === -1 && carto.area)
return false;
if ($scope.searched.block.indexOf(carto.block) === -1 && carto.block)
return false;
if ($scope.searched.type.indexOf(carto.type) === -1 && carto.type)
return false;
if ($scope.searched.level.indexOf(carto.level) === -1 && carto.level)
return false;
if ($scope.searchInput) {
var searchRegex = new RegExp($scope.searchInput, 'i');
if (carto.fullDisplayName.search(searchRegex) === -1)
return false;
}
if (!$scope.homeVisible) {
$scope.homeVisible = true;
window.history.pushState("newUrl", "CartoViewer", window.location.origin + window.location.pathname);
}
return true;
}
else
return true;
};
【问题讨论】:
-
在搜索功能中实现计数器。
-
显示的图块数只是
cartoList.length。可以使用$index找到每个迭代的索引 -
@RGraham :
cartoList.length是瓷砖的数量(总计:显示和隐藏,包括那些与我的ng-if不匹配的瓷砖)@Rohit Kumar :Implementing a counter in mysearch` 功能,不适合我,因为它针对不同的过滤器经历了几个循环,并为相同的carto多次返回true -
@Ellone 你能提供来自控制器的
search(carto)代码吗? -
@Ellone 我明白你现在的意思了。这似乎是一个奇怪的模式。如果您的商品不显示,为什么它们甚至在
cartoList中?似乎search()应该发生在ng-repeat之外,只留下你需要的物品,而不必ng-if每个单独的物品
标签: javascript html angularjs angularjs-ng-repeat angular-ng-if