前言
写前端的时候难免遇到数据展示问题,比如 form 表单,在 使用 FormBuilder 来生成表单控件 时,当 input 输入框较多的时候,我们可能希望能够自主控制表单字段顺序,此时,则需要对表单字段进行排序。那么,如何实现呢?
使用内置 orderBy
<li ng-repeat="item in items | orderBy:'color'">{{ item.color }}</li> |
参见AngularJS orderBy 使用要点 - 佣工 7001 - 博客园
没有 orderBy 怎么办
从 Angular 开始 orderBy 不再支持,此时无法直接使用。
update附录:没有 FilterPipe 或者 OrderByPipe
使用开源包 ngx-order-pipe
如果不考虑性能问题,可以使用这样的方式:
参见 Angular 5+ Order Pipe
这个包可以实现列表式数据的排序,具体用法参见文档。
注意:可能遇到The pipe 'orderBy' could not be found
错误,这个可以翻阅 issue 解决,我自己的实践是放在使用的组件的上一层级目录下面。如图:
自定义 pipe 造轮子
参见 angular2 自定义 pipe ,orderby 实现排序JavaScript兰色的 fire-CSDN 博客
如果返回的值是 Object 怎么办
- 使用 KeyValuePipe 组件。参考Angular 6 - KeyValue Pipe - *ngFor Loop through Object, Map example » grokonez
- 将 Object 遍历,然后排序放到列表中,代码参见:
app.filter('orderObjectBy', function() {
return function(items, field, reverse) {
var filtered = [];
angular.forEach(items, function(item) {
filtered.push(item);
});
filtered.sort(function (a, b) {
return (a[field] > b[field] ? 1 : -1);
});
if(reverse) filtered.reverse();
return filtered;
};
});
结语
文章写出来了才翻到官方文档中的建议,所以这篇文章意义也不大了。不过还是做一个记录吧,这也说明使用框架前先阅读官方文档的必要性。
顺便参考一下怎么实现数组的排序sort()方法实现对象数组的排序