javascript – ng-repeat中的AngularJS“标题”

前端之家收集整理的这篇文章主要介绍了javascript – ng-repeat中的AngularJS“标题”前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个问题,最近出现的问题多于一个,我想知道最好的方法.简单说明一下:

我有数据显示在ng-repeat中,按特定项目排序.比如说它按名称排序.我的目标是在字母顺序列表中的字母处打开标题

----A----
Abe Lincoln
Adam Smith
----B----
Barack Obama
Barry Zuckercorn
----C----
...

等等.

我尝试过的事情包括

>让控制器完全重建模型的数据,手动将其放入一组字母组中.例如,我的服务有一系列“帖子”,我的控制器在服务更新时,手动将这些“帖子”洗牌为“letterGroups”数组.然后可能只有两个嵌套的ng-repeats

但是,这依赖于对数据的大量操作,并且不容易改变数据的动态排序.

>当模型更新时,让控制器通过手动单步执行数据来“填充”数据,检查字母何时更改,并在该元素上搭载“header”属性(post.header = true).然后ng-repeat可以检查它当前所在的元素是否是标题,并使用ng-if将其他内容插入到DOM中.

这感觉稍微干净但是由于ng-repeat的工作方式,标题元素必须“包含”在与ng重复元素相同的水平.例如,如果你在< tr>上进行ng-repeat.元素,这意味着不可能插入另一个< tr>对于标题,因为特殊元素必须出现在< tr>内.

最后,沿着与上面相同的方向:

>让控制器维护一个“关键索引”列表 – 这样做的好处是不像上面的第二种方法那样修改数据,但通常以相同的方式工作.

编辑:

我写了一篇here博客文章,解释了我最终如何处理这个问题 – 感谢由Ian在下面的回答链接的Google Groups讨论.

解决方法

创建角度过滤器.它可以接受排序列表,按第一个字母对其进行分块,并为每个块返回一个对象,其中包含字母和以该字母开头的对象数组.

请参阅例如chunk by size filter here.特别注意有关为分块值创建哈希值的讨论.

原文链接:https://www.f2er.com/js/157688.html

猜你在找的JavaScript相关文章