LayoutAnimation
当下一次布局发生时,自动将视图动画化到它们的新位置。
使用此 API 的常见方法是在函数组件中更新 state hook 之前调用它,以及在类组件中调用 setState 之前调用它。
注意,为了使其在 Android 上工作,你需要通过 UIManager 设置以下标志:
js
if (Platform.OS === 'android') {
if (UIManager.setLayoutAnimationEnabledExperimental) {
UIManager.setLayoutAnimationEnabledExperimental(true);
}
}
示例
参考
方法
configureNext()
tsx
static configureNext(
config: LayoutAnimationConfig,
onAnimationDidEnd?: () => void,
onAnimationDidFail?: () => void,
);
安排一个动画在下一次布局时发生。
参数:
| 名称 | 类型 | 必填 | 描述 |
|---|---|---|---|
| config | object | 是 | 见下方的配置描述。 |
| onAnimationDidEnd | function | 否 | 动画完成时调用。 |
| onAnimationDidFail | function | 否 | 动画失败时调用。 |
config 参数是一个包含以下键的对象。create 返回一个有效的 config 对象,Presets 对象也都可以作为 config 传递。
duration毫秒数create,用于动画化新视图进入的可选配置update,用于动画化已更新视图的可选配置delete,用于动画化视图移除时的可选配置
传递给 create、update 或 delete 的配置具有以下键:
type,要使用的 动画类型property,要动画化的 布局属性(可选,但建议用于create和delete)springDamping(number,可选,仅与type: Type.spring一起使用)initialVelocity(number,可选)delay(number,可选)duration(number,可选)
create()
tsx
static create(duration, type, creationProp)
辅助函数,创建一个对象(包含 create、update 和 delete 字段)以传递给 configureNext。type 参数是一个 动画类型,creationProp 参数是一个 布局属性。
示例:
属性
类型
要在 create 方法中使用的动画类型枚举,或在 configureNext 的 create/update/delete 配置中使用。(示例用法:LayoutAnimation.Types.easeIn)
| 类型 |
|---|
| spring |
| linear |
| easeInEaseOut |
| easeIn |
| easeOut |
| keyboard |
属性
要在 create 方法中使用的要动画化的布局属性枚举,或在 configureNext 的 create/update/delete 配置中使用。(示例用法:LayoutAnimation.Properties.opacity)
| 属性 |
|---|
| opacity |
| scaleX |
| scaleY |
| scaleXY |
预设
一组预定义的动画配置,传递给 configureNext。
| 预设 | 值 |
|---|---|
| easeInEaseOut | create(300, 'easeInEaseOut', 'opacity') |
| linear | create(500, 'linear', 'opacity') |
| spring | {duration: 700, create: {type: 'linear', property: 'opacity'}, update: {type: 'spring', springDamping: 0.4}, delete: {type: 'linear', property: 'opacity'} } |
easeInEaseOut
使用 Presets.easeInEaseOut 调用 configureNext()。
linear
使用 Presets.linear 调用 configureNext()。
spring
使用 Presets.spring 调用 configureNext()。
示例: