栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

AngularJS CSS动画+完成回调

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

AngularJS CSS动画+完成回调

是的,您可以使用该

$animate
服务,这通常是在自定义指令中完成的。动画的一个简单例子是在单击时以某种方式对元素进行动画处理。例如,说要删除点击元素,并使用.ng-leave指定的动画传递回调

app.directive('leaveOnClick', function($animate) {  return {    scope: {      'leaveOnClick': '&'    },    link: function (scope, element) {      scope.leaveonClick = scope.leaveonClick || (function() {});      element.on('click', function() {        scope.$apply(function() {          $animate.leave(element, scope.leaveOnClick);        });      });    }  };});

可以这样使用:

<div  leaveonClick="done()">Click to remove</div>

使用CSS淡出元素:

.my-div.ng-leave {  opacity: 1;  transition: opacity 1s;  -webkit-transition: opacity 1s;}.my-div.ng-leave.ng-leave-active {  opacity: 0;}

您可以在此Plunker上看到以上动画的动作。

但是,据我所知,ngIf没有任何挂钩可以传递回调,因此您必须编写自己的指令。以下是对ngIf修改版本的描述,该版本最初是从ngIf源复制并重命名为

animatedIf
。可以由以下人员使用:

<div  animated-if="shown" animated-if-leave-callback="leaveDone()" animated-if-enter-callback="enterDone()" >Some content</div>

它的工作方式是使用手动观察器对传递给的表达式的更改做出反应

animated-if
。与原始ngIf的主要区别在于添加了“
scope”参数以在以下位置传递回调:

scope: {  'animatedIf': '=',  'animatedIfEnterCallback': '&',  'animatedIfLeaveCallback': '&'},

然后在动画之后修改对的调用

$animate.enter
$animate.leave
调用这些回调:

var callback = !oldValue && $scope.animatedIfEnterCallback ? $scope.animatedIfEnterCallback : (function() {});$animate.enter(clone, $element.parent(), $element, callback);$animate.leave(block.clone, ($scope.animatedIfLeaveCallback || (function() {})));

回车键有点复杂,要在初始加载指令时不调用回调函数。由于有此

scope
参数,此伪指令创建一个隔离的作用域,然后在包含内容时使用它。因此,需要进行的另一项更改是从
$parent
指令的作用域中创建作用域并将其用作子元素:

 childScope = $scope.$new();

必须更改为

 childScope = $scope.$parent.$new();

您可以在此Plunker中看到修改后的ngIf指令的完整源代码。这只是经过极其简短的测试。

可能有一种更简单的方法,也许是不完全重新创建ngIf指令,而是使用包含原始ngIf和某些包装div的模板创建一个指令,例如

template: '<div><div ng-if="localVariable"><div ng-transclude></div></div></div>'


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/432601.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号