gpt4 book ai didi

angularjs - ionic 收集 - 带日期分隔符的重复

转载 作者:行者123 更新时间:2023-12-02 18:22:45 28 4
gpt4 key购买 nike

我得到了一个非常大的列表,其中包含大约 200 个带有文本和图像的项目。 ng-repeat 是一种缓慢渲染的方式。它尝试过这个 solution 。效果很好。但不适合重复收集。

我的网络服务返回此:

enter image description here

有特定日期的事件。事件应按日期分组。因此,为了使用集合重复,如果不能使用 angular.filter groupBy,如何插入分隔符?

最佳答案

我可以为您提供一个部分解决方案,该解决方案仅在数据集按分隔线中显示的字段排序时才有效。

首先,我们需要在数组中创建一个假元素,以便我们可以区分其他元素中的分隔符。

假设我们有从网络服务获取的帖子集合:

.controller('mainController', function($scope, dataService) {
$scope.posts = [];
var divider = '';
});

the private field divider will be in use when we load the posts.

当我们滚动列表时,我们将有 loadMore 方法来加载额外的数据:

$scope.loadMore = function(argument) {
page++;
dataService.GetPosts(page, pageSize)
.then(function(result) {
if (result.data.length > 0) {
angular.forEach(result.data, function(value, key) {
value.divider = false;
if (value.postId !== divider)
{
divider = value.postId;
$scope.posts.push({divider: true, dividerText: value.postId});
}
$scope.posts.push(value);
});
}
else {
$scope.theEnd = true;
}
})
.finally(function() {
$scope.$broadcast("scroll.infiniteScrollComplete");
});
};

当我们从 Web api 获取数据(并且 promise 已解决)时,我们循环遍历集合并检查该字段是否与分隔符不同。如果这是一个新的分隔符,我们存储信息并向集合添加一个新元素:

angular.forEach(result.data, function(value, key) {
value.divider = false;
if (value.postId !== divider)
{
divider = value.postId;
$scope.posts.push({divider: true, dividerText: value.postId});
}
$scope.posts.push(value);
});

如您所见,我添加了一个元素:

$scope.posts.push({divider: true, dividerText: value.postId});

我使用了 dividerText 字段,稍后将显示该字段。

现在我们需要创建自己的指令divider-collection-repeat,该指令应附加到集合重复:

<ion-item collection-repeat="post in posts" item-height="75" divider-collection-repeat>

我猜您正在使用无限滚动,所以这里是整个 HTML:

  <ion-content ng-controller="mainController">
<ion-list>
<ion-item collection-repeat="post in posts" item-height="75" divider-collection-repeat>
{{post.name}}
</ion-item>
</ion-list>
<ion-infinite-scroll ng-if="!theEnd" on-infinite="loadMore()" distance="50%"></ion-infinite-scroll>
</ion-content>

这是指令:

.directive('dividerCollectionRepeat', function($parse) {

return {
priority: 1001,
compile: compile
};

function compile (element, attr) {
var height = attr.itemHeight || '75';
var itemExpr = attr.collectionRepeat.split(' ').shift();
attr.$set('itemHeight', itemExpr + '.divider ? 40 : (' + height + ')');
attr.$set('ng-class', itemExpr + '.divider ? "item-divider" : ""');
var children = element.children().attr('ng-hide', itemExpr + '.divider');
element.prepend(
'<div ng-show="' + itemExpr + '.divider" class="my-divider" ' +
'ng-bind="' + itemExpr + '.dividerText" style="height:100%;">' +
'</div>'
);

return function postLink(scope, element, attr) {
scope.$watch(itemExpr + '.divider', function(divider) {
element.toggleClass('item-divider', !!divider);
});
};

}

});

该指令使用您在集合重复中定义的表达式将元素 (html) 添加到列表中。

在我的示例中,我使用了 collection-repeat="post in posts" 所以这一行:

var itemExpr = attr.collectionRepeat.split(' ').shift();

获取项目的名称;就我而言,它将是post

我们也使用高度,因为我们可能需要为分隔线设置不同的高度。

这里是所有魔法发生的地方:

  element.prepend(
'<div ng-show="' + itemExpr + '.divider" class="my-divider" ' +
'ng-bind="' + itemExpr + '.dividerText" style="height:100%;">' +
'</div>'
);

它使用 ng-show 作为字段 'post.divider' (ng-show="' + itemExpr + '.divider") 并绑定(bind)我们的文本字段 ng-bind="' + itemExpr + '.dividerText"

我还添加了一个自定义类 my-divider 以防万一我们需要稍微更改分隔线的布局。

最终结果为here或者在这个plunker .

您可能已经注意到,我没有使用日期字段,因为我已经有一个示例,遗憾的是,我没有任何日期。我想应该很容易适应你的情况。

该指令基于我在 github 上找到的示例。您将找到指令 here 的代码.

关于angularjs - ionic 收集 - 带日期分隔符的重复,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33017548/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com