当前位置: 首页 > 面试题库 >

用于平滑排序ng-repeat的ngAnimate示例?

刘明朗
2023-03-14
问题内容

我想看一个使用角度动画(1.2x)对列表进行排序的功能示例。(我只在互连网上碰到过破烂的小提琴等):

给定数组[A,B,C]和随后的[C,B,A]的ng-repeat应该:

  • 将A移至底部
  • 将C移到顶部
  • 保持B的位置

(使用CSS绝对顶部位置或类似位置。)

使用交错(过渡延迟)的示例是一个加分项。


问题答案:

问题

实现您想要的内容可能会有些棘手。

一种常见的尝试是ng-style根据列表中的元素索引来计算元素的位置:

<div ng-repeat="c in countries | orderBy:q" ng-style="{ 'top': $index * 20 + 'px' }">

演示: http
//plnkr.co/edit/anv4fIrMxVDWuov6K3sw?p =
preview

问题在于,只有某些元素是动画的,并且仅朝着底部。

这是为什么?

考虑以下按名称排序的列表(类似于上面演示中的列表):

  • 2-丹麦
  • 3-挪威
  • 1-瑞典

当您按ID对列表进行排序时,只会移动一个元素-
瑞典从下到上。实际上发生的是,将瑞典元素从DOM中删除,并在其新位置再次插入。但是,当将元素插入DOM时,通常不会发生关联的CSS转换(我之所以说是正常的,因为它最终取决于相关浏览器的实现方式)。

其他两个元素保留在DOM中,获得新top位置,并且它们的过渡具有动画效果。

因此,采用这种策略时,只会为未在DOM中实际移动的元素设置过渡动画。

另一种策略是包括ngAnimate模块并使用该CSS类ng-move。动画ng-repeats的几乎所有示例都使用此功能。

但是,由于两个原因,这将无法正常工作:

  1. ng-move类只被施加到元素移动(因此仅在上面的例子中的瑞典元件)

  2. ng-move将元素插入到DOM中的新位置后,该类将应用于该元素。您可以使用CSS表示“从不透明度0到1进行动画处理”,但是您不能使用“从旧位置到新位置进行动画处理”,因为不知道旧位置并且每个元素都必须移动不同的距离。

一个办法

我过去使用的一种解决方案是ng- repeat用于呈现列表,但从不实际使用基础数据。这样,所有DOM元素都将保留在DOM中并可以进行动画处理。要正确渲染元素,请使用ng- style和自定义属性,例如:

ng-style="{ 'top': country.position * 20 + 'px' }"

要更新position属性,请执行以下操作:

  1. 创建基础数据的副本

您可以angular.copy用来复制整个阵列,但是对于大型阵列,这对性能不利。这也是不必要的,因为复制数组中的每个对象仅需要一个唯一的属性,并且该属性可以按以下顺序排序:

        var tempArray = countries.map(function(country) {
      var obj = {
        id: country.id
      };
      obj[property] = country[property];
      return obj;
    });

在上面的示例id中,Unique属性是唯一的,并且property是一个html" target="_blank">变量,其中包含要排序的属性的名称,例如name

  1. 排序副本

要使用Array.prototype.sort()比较功能对数组进行排序:

```
tempArray.sort(function(a, b) {
if (a[property] > b[property])
return 1;
if (a[property] < b[property])
return -1;
return 0;
});


  3. 将位置设置为已排序副本中元素的索引

    countries.forEach(function(country) {
  country.position = getNewPosition(country.id);
});

function getNewPosition(countryId) {
  for (var i = 0, length = tempArray.length; i < length; i++) {
    if (tempArray[i].id === countryId) return i;
  }
}

```

有改进的余地,但这是基础。

演示: http :
//plnkr.co/edit/2Ramkg3sMW9pds9ZF1oc?p=preview

我实现了一个使用交错的版本,但是它看起来有点怪异,因为元素会暂时相互重叠。



 类似资料:
  • 问题内容: 我有一个HTML表格,想通过单击表格标题(在ctrl中)对记录(在ctrl中)进行排序, 任何人都可以解释为什么这样做有效: 那不是: 这是记录的代码: 我的表格中有58列,因此遍历表格标题会更好。 问题答案: 正如David所建议的,这可能与范围有关。由于ngRepeat创建了一个新的作用域,因此您需要为每个列标题设置和。 确保您在同一范围内修改值的一种方法是在该范围内创建一个函数,

  • 问题内容: 如何按键排序为整数? 我有以下对象; HTML: 当前的输出顺序是 但是我想要 不要为我工作。 有任何想法吗? 谢谢! 问题答案: 一种选择是使用中间过滤器。 代码和代码段 注意: 上面的过滤器需要Underscore.js,如果不使用它,可以重写过滤器。

  • 问题内容: 我有一组显示一定数量的磁贴,具体取决于用户选择的选项。我现在想通过显示的任何数字来实现排序。 下面的代码显示了我是如何实现的(通过在父卡范围内获取/设置一个值)。现在,由于orderBy函数接受一个字符串,因此我尝试在卡范围内设置一个名为curOptionValue的变量并以此进行排序,但似乎不起作用。 因此,问题就变成了,如何创建自定义排序功能? 和控制器: 问题答案: 实际上,过滤

  • 问题内容: 有谁知道当我使用ng-repeat时如何完全 跳过 JSON排序(可能以一种轻松的方式)? 例如,我的源JSON看起来像这样- 一旦在ng-repeat中使用它,它就会按字母顺序排序。像这样- 我的ng-repeat看起来像这样- 我见过人们有一个单独的键数组,并使用它们来标识JSON对象,最终避免了字母排序。 有没有一种优雅的方法可以做到这一点? 问题答案: 在Google网上论坛找

  • 问题内容: 我试图了解over 的意义。角度文档提供了以下示例 但是,使用, 有人可以解释。的意义吗?谢谢。 问题答案: 这两个指令的含义相似:它们重复HTML标记。所不同的只是,在您的帮助下,您可以重复几个标签,从标签开始于,再到完成于。 例如,您有下一个代码: 因此,现在我们可以为这些代码添加2个指令。 与: 与和: 因此,现在您可以看到,在第一种情况下,仅使用指令重复,但是在第二种情况下,您

  • 问题内容: 嗨,我有一个简单的ng-repeat-start和end用例,并且工作正常,当我想添加一个内部ng-repeat时出现了问题。这是我的代码 内部ng-repeat到td元素中不起作用,在检查html源代码时看到ngRepeat注​​释,但未创建td元素。 我的丑陋的解决方法(假设我知道该向量的大小)是: 问题答案: 从那时起,我不确定是否使用角度1.1.6,并且在1.1.5或1.0.7