React native 使用Animated 优化连续setState 性能问题

再部分场景下我们需要连续更新state刷新页面。一般情况刷新使用setstate没有问题,当需要连续刷新的情况会有明显的性能问题。

场景: 自定义可拖动抽屉组件 新增需求在抽屉活动是更新主页面组件样式,此时需要动态传递抽屉高度修改主页组件属性。

**实现:**在原有组件增加动画属性的监听:

javascript 复制代码
/**

* 监听参数变化

*/

this.watcher = this.animatedViewHeight.addListener((v) => {

 let height = this.props?.maxHeight < v?.value ? this.props?.maxHeight : v?.value

 this.props?.watcher && this.props?.watcher(height);

})

//在父组件接受并setState修改组件

<DraggableView

 initialHeight={initialHeight}

 maxHeight={deviceInfo.phone_screen_height * 0.75} watcher={(v) => {

 this.setState({ buttonBottom: v || initialHeight })

}}>

**问题:**由于动画属性的刷新过于平凡,调用setState明显卡顿

**优化:**使用Animated动画替换,使自定义回调变为一个动画驱动

javascript 复制代码
<DraggableView 
 initialHeight={initialHeight} 
 maxHeight={deviceInfo.phone_screen_height * 0.75} 
 watcher={Animated.event(

    [

        {}//dy:this.animatedViewHeight

    ],

    {

        listener: (v) => {

            this.animatedButtonBottom.setValue(v)

        }

    }

)}>

第一个中括号重定义动画接受属性 如需要过滤特定属性使用{x:y.value}方式实现,此时第二个大括号中的参数v 相当于 y.value. 。不做操作则v相当于回调回传的值y

javascript 复制代码
//定义动画属性
this.animatedButtonBottom = new Animated.Value(initialHeight * 1)//动态按钮位置高度
javascript 复制代码
//在动画组件使用
<Animated.View style={[styles.toLocationDetail, { bottom: this.animatedButtonBottom }]}/>
相关推荐
用户新12 分钟前
五万字沥血事件 深度学习 事件 循环 事件传播 异步 脱离新手区 成为事件达人
前端·javascript·事件·event loop
w2sfot20 分钟前
JS代码压缩
前端·javascript·html
这是个栗子30 分钟前
【JS知识点总结】JavaScript 中的精确取整:Math.floor、Math.ceil 与 Math.round
开发语言·javascript·ecmascript
一只爱吃糖的小羊1 小时前
React 19:革命性升级与全面使用指南
react.js
一只爱吃糖的小羊1 小时前
React 19 vs Vue 3:深度对比与选型指南
前端·vue.js·react.js
我也想好好学习1 小时前
使用Promise实现串行执行异步任务,含出错重试功能
javascript
前端老宋Running1 小时前
Vue 3 的“降维打击”:Composition API 是如何让 Mixin 成为历史文物的?
前端·javascript·vue.js
Pluto_CRown1 小时前
H5 开发的各类小知识点
前端·javascript
Pluto_CRown1 小时前
上下文存储【下】
前端·javascript
AAA阿giao1 小时前
JavaScript 中基于原型和原型链的继承方式详解
前端·javascript·面试