介绍
ANIX是一个轻量级且易于使用的动画库,在现代浏览器发挥优良的性能和良好的兼容性。它采用了原生的CSS属性的过渡,不是JS模拟动画,因此性能更好。并且可以使用硬件加速。ANIX不到3K的大小
有多种版本的ANIX实现,UMD版本,jQuery的版本和React版本等…
data:image/s3,"s3://crabby-images/737a1/737a1d8798745bc162c3cfd57805cadf0c52ba3e" alt="3c013fff7e744f8db1eb93a5b7563362 3c013fff7e744f8db1eb93a5b7563362"
Github
https://github.com/drawcall/AniX
简单使用
PS:可以先看demo标题进行预览,动态展示
使用npm进行包管理安装
$ npm install anix
umd版本
<script src="./js/anix.umd.ts" type="text/javascript"></script>
jquery版本
<script src="./js/jquery.js" type="text/javascript"></script>
<script src="./js/anix.jq.ts" type="text/javascript"></script>
//1. 导入AniX
import { AniX } from 'anix';
//2. AniX.to
AniX.to(dom, 1, {
width: "200px",
height: "100px"
});
一共有以下四种方式可用
//AniX.to
$(..).to(time: number, args: {ease?:string; delay?:number; [propName:string]:any;})
//AniX.fromTo
$(..).to(time: number, fromArgs: Object, toArgs: Object)
//AniX.kill
$(..).kill(complete?: boolean)
//AniX.get
$(..).getTransform(param: any)
//AniX.ease
$.ease.easeOut
React中使用
class MyComponent extends React.Component {
constructor(props) {
super(props);
this.myRef = React.createRef();
this.clickHandler = this.clickHandler.bind(this);
}
clickHandler(e) {
const node = this.myRef.current;
// animation
AniX.to(node, 1, {
x: 300,
y: 10,
scale: 2
});
}
render() {
return (
<div>
<div ref={this.myRef} />
<button onClick={this.clickHandler}></button>
</div>
);
}
}
Demo预览
data:image/s3,"s3://crabby-images/737a1/737a1d8798745bc162c3cfd57805cadf0c52ba3e" alt="ca356a2786b1463abced678effde97c3 ca356a2786b1463abced678effde97c3"
data:image/s3,"s3://crabby-images/737a1/737a1d8798745bc162c3cfd57805cadf0c52ba3e" alt="a928186376ca4a5496e0777efd66e746 a928186376ca4a5496e0777efd66e746"
data:image/s3,"s3://crabby-images/737a1/737a1d8798745bc162c3cfd57805cadf0c52ba3e" alt="c7aa5f2a56f84499aa836b7e8393f479 c7aa5f2a56f84499aa836b7e8393f479"
data:image/s3,"s3://crabby-images/737a1/737a1d8798745bc162c3cfd57805cadf0c52ba3e" alt="5767fd5301244440b4b757ad0b484b57 5767fd5301244440b4b757ad0b484b57"
data:image/s3,"s3://crabby-images/737a1/737a1d8798745bc162c3cfd57805cadf0c52ba3e" alt="050f607f5f9f4e71a0ecbc54d86f1576 050f607f5f9f4e71a0ecbc54d86f1576"
data:image/s3,"s3://crabby-images/737a1/737a1d8798745bc162c3cfd57805cadf0c52ba3e" alt="98c048d5bed84cbbbf20d82a814b5534 98c048d5bed84cbbbf20d82a814b5534"
总结
AniX具备良好的兼容性,经历过很多真机测试,性能好且包括各种Android设备等,是一个不错的动画库,enjoy it!