AngularJS 1.4对动画系统进行了彻底的重构
分享 《关于我》
分享 [中文纪录片]互联网时代 http://pan.baidu.com/s/1qWkJfcS
AngularJS 团队刚刚宣布了1.4发布候选版的问世,对内部的动画代码系统进行了彻底的重构。
在1.4版本中,ngAnimate使用了新的动画系统,通过回调钩子支持基于CSS的动画以及基于JavaScript的动画。
Google在这个JavaScript框架的 发布说明 中表示,在新的 $animate 特性中“ngAnimate的全部代码都进行了重写,以使内部的动画代码更加灵活、重用性更高并且性能更出色。”
Matias Niemelä是来自Google的一位软件工程师,他在 Google+上的一篇帖子 中宣布了在1.4版本中ngAnimate所包含的“一系列新特性与bug修复”。
包括以下内容:
- 使用$animateCss通过命令式的方式控制或触发基于CSS的转换和关键帧
- (使用ng-animate-ref)生成跨页面的跨动画元素
- 使用$animate中新的API处理回调
- 包括大量与回流相关的bug修复,并且将提供一个更好的基础,以便在即将到来的1.5版本中能够实现更多的特性。
$animate在新的版本中也产生了大量的破坏性改动。其中最引人注目的一条是,JavaScript与CSS动画将无法并行地运行了。在之前的版本中,通过使用ngAnimate,当检查到多个动画运行时,可以同时运行CSS与JS的动画。
不过,虽然这一特性从1.4版本中被移除,但AngularJS对此表示“通过将$animateCss注入到某个由JavaScript定义的动画中,并且在其中创建自定义的基于CSS的动画,可以实现相同的效果,甚至还能够带来更多的可能性”。
$animate在新版本中的破坏性改动还包括$animate.enabled()这个函数的参数的变化,当调用$animate.enabled()这个函数时使用某个单一元素的的话,那么该函数将表现为一种getter方法。
$animate的另一个破坏性发动是“在动画的promise回调中无需调用$scope.$apply或$scope.$digest了,因为该promise已经通过一个digest进行自动解析了(但如果没有对promised进行链式调用,digest是不会自动运行的)”
使用$animateCss通过命令式的方式控制或触发基于CSS的转换和关键帧
(使用ng-animate-ref)生成跨页面的跨动画元素
使用$animate中新的API处理回调
包括大量与回流相关的bug修复,并且将提供一个更好的基础,以便在即将到来的1.5版本中能够实现更多的特性。
// < 1.4
$animate.enter(element).then(function() {
$scope.$apply(function() {
$scope.explode = true;
});
});
// 1.4+
$animate.enter(element).then(function() {
$scope.explode = true;
});
可以在 这里 找到关于其它破坏性改动的更多细节。
Angular 1.4版本的开发代号为 smooth-unwinding ,其中也包括了多个性能改进之处,包括对ngOptions的改动,现在它只在使用track by的情况下才会对ngModel进行深度等同性测试。此外,当Angular app卸载时,$rootScope也会移除历史事件的处理器。
1.4原本计划在2015年3月份发布,当时 ng-conf 这个关注于AngularJS的大会正在如火如荼地进行中。在1.4版本发布之后,AngularJS 1.5的工作就将正式展开。Brad Green是Google工程团队的总监,也是Angular开发计划的领导人,他在ng-conf大会之后 宣布 ,1.5版本的主题是支持与Angular 2的整合。
虽然整个Angular社区对于2.0版本仍然保有很大的疑惑和困惑,但Google已经表示他们将继续在angularjs.org上维护Angular 1.X版本,而在 angular.io 上发布Angular 2.0的Alpha版本。在ng-conf大会上Google也再次对社区明确表态:在Angular 2.0版本的流量占到上风之前,他们绝对不会结束Angular 1.X的生命。
AngularJS 1.4对动画系统进行了彻底的重构的更多相关文章
- Unity Animation System(动画系统)
动画系统: 支持:动画融合,混合,叠加动画,行走循环的时间同步,动画层,控制动画的各个方面(时间,速度,融合权重) 带有每顶点1.2或4骨骼的蒙皮网格,以及支持基于物理的布娃娃系统和程序动画. ...
- Android动画学习(一)——Android动画系统框架简介
2015-11-09补充:Drawable Animation极有可能是Frame Animation 这几天在找工作,面试的时候被问到了Android动画,之前完全没接触过这部分,直接给懵了,当然其 ...
- unity3D5旧动画系统注意事项
最近在写人物控制时因为习惯用旧动画系统所以也没想那么多,就直接在新系统下按照老样子写了,突然发现animation.play不能用了,后来重新声明了变量: public Animation anim; ...
- unity5.0新功能-布料、动画系统
原作者:只待苍霞 这一章讲一下布料系统, 这次的布料系统有很大的改良.Unity4中, 需要对SkinnedMeshRenderer使用SkinnedCloth, 或者对Cloth Renderer使 ...
- 【腾讯GAD暑期训练营游戏程序开发】游戏中的动画系统作业
游戏中的动画系统作业说明文档 一.实现一个动画状态机:至少包含3组大的状态节点
- 时光煮雨 Unity3D实现2D人物动画② Unity2D 动画系统&资源效率
系列目录 [Unity3D基础]让物体动起来①--基于UGUI的鼠标点击移动 [Unity3D基础]让物体动起来②--UGUI鼠标点击逐帧移动 时光煮雨 Unity3D让物体动起来③—UGUI DoT ...
- Unity3D Mecanim 动画系统骨骼动画问题解决方法
http://7dot9.com/2014/08/16/unity3d-mecanim%E5%8A%A8%E7%94%BB%E7%B3%BB%E7%BB%9F%E9%AA%A8%E9%AA%BC%E5 ...
- Unity3d之Mecanim(新版动画系统)
1,动画系统配置,2,代码控制动画 原文地址:http://blog.csdn.net/dingkun520wy/article/details/51247491 1,动画系统配置 创建Animato ...
- Unity3D之Legacy动画系统学习笔记
Unity3D的Mecanim动画系统是非常强大的,而且作为Unity推荐的动画系统,其未来会完全代替老的一套动画系统,即Legacy动画系统.目前的情况是Mecanim与Legacy两套动画系统同时 ...
随机推荐
- NOIP模拟 Math - 数学
题目大意: 给定a,n(\(a \le 1e9, n\le30\)),求有多少\(b(1 \le b \le 2^n)\)满足:\(a^b \equiv b^a(mod 2^n)\). 题目分析: 数 ...
- 语言的学习 —— 西班牙语(español)
联合国六大官方语言:英语.法语.俄语.汉语.西班牙语.阿拉伯语: 在七大洲中,主要是在拉丁美洲国家中(巴西.伯利兹.法属圭亚那.海地等地除外).很多说西班牙语的人把他们的语言称为西班牙语(españo ...
- 不要放弃使用border-box
不知道有多少老前端像我这样,在项目中很少使用box-sizing这个属性值.因为CSS2.1中只有content-box这一种盒子模式,在CSS3还没有流行的时候,大家在工作中大量基于这种盒子模式写C ...
- 多域名绑定同一IP地址,Node.js来实现
本来打算用Nginx来实现,看了一会Nginx的配置,感觉又要费时间学习,就抱着试试看的心在网上搜,是否可以用Node.js来实现. 没想到,竟然搜到了.想试一下,但国内域名备案时间长达一个月,我肯定 ...
- TstringBuilder Delphi2007版
2010中的StringBuilder对象用的比较爽快!于是稍作了一些修改(增加了几个函数和属性)然后移植到D2007中来使用了!效果不错,共享一下! unit DxStringBuilder; in ...
- Winsock出错引起的断网
背景 实验室有二十来台 PC 机,30+的服务器集群,网络拓扑比较复杂.简单地说,有网关连着校网,校网无法直接访问学校外的网络,只能通过拨 vpn 来实现外网访问.而校网最近也不稳定,时常断网. 今天 ...
- eclipes 常用的快捷键 , 修改字体
内容辅助键 Alt+/ 自动补齐main方法 main 然后 Alt+/ 自动补齐输出语句 syso 然后 Alt+/ 格式化Ctrl+Shift+f 代码区域右键 -- Source – Fo ...
- Managing uniquely tagged items using the internet
The invention teaches managing an item in the Internet of Things, wherein the system comprises: an i ...
- 让你编写的控件库在 XAML 中有一个统一的漂亮的命名空间(xmlns)和命名空间前缀
原文 让你编写的控件库在 XAML 中有一个统一的漂亮的命名空间(xmlns)和命名空间前缀 在 WPF XAML 中使用自己定义的控件时,想必大家都能在 XAML 中编写出这个控件的命名空间了.然而 ...
- 实现网站https
双击上面的服务器证书 如下图: