博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
React Native 折叠功能的实现及安卓踩坑笔记
阅读量:7101 次
发布时间:2019-06-28

本文共 1371 字,大约阅读时间需要 4 分钟。

hot3.png

市面上有相应的插件 react-native-collapsible, 但它在折叠状态底部有莫名其妙的空白,且有很多bug未解决, 于是自己试着实现了一个简版。

基础结构

{ this.props.children }
const S = StyleSheet.create({ container: { overflow: 'hidden' }, content: { position: 'absolute', top: 0, left: 0, right: 0 }})

我们需要能动态控制显示高度,会用到overflow:hidden,而默认状态是折叠的,因此,为了获取实际内容的真实高度(不固定),需加两层嵌套,以便通过onLayout方法提前得到展开后的高度。

这是开启动画的前提。

动画的实现

这里介绍两种方式

Animated Component

这是我常用的技巧。首先把container里面的元素用Animated.View封装:

...

其中height初值为new Animated.Value(0),数值0表示完全折叠。

然后当展开时,给height应用动画即可:

Animated.timing(  this.state.height,  {    toValue: newHeight,    duration: this.props.duration || 300,    easing: this.props.easing || Easing.linear  }).start()

这里newHeight为新的高度值,比如第一步中通过onLayout得到的真实高度。

反之亦然,折叠时,再设为0即可。

LayoutAnimation

这是从上学到的技巧,原作者不详。

这种方法不需要再次封装,代码相对简洁得多。这回我们直接在container上设置height

...

然后当折叠或展开时,设定动画并更新高度值:

LayoutAnimation.configureNext( LayoutAnimation.Presets.easeInEaseOut )this.setState({ height: newHeight })

注意事项

在安卓机上,需要手动开启动画:

if ( Platform.OS === 'android' ) {  UIManager.setLayoutAnimationEnabledExperimental(true)}

踩坑

安卓下内容溢出

尽管设置了overflow:hidden,安卓下内容仍然会溢出一部分,然后和下方的内容层叠了,丑爆。

不能说overflow无效,但又不完全符合预期,试了多种方法包括改结构,均无效,太认人沮丧了。

为了方便调试,就加了背景色,居然好了。莫名其妙的就好了!

所以解决方法是——设定背景色。

over

转载于:https://my.oschina.net/u/2324376/blog/2963010

你可能感兴趣的文章
三层交换+DHCP实验详解
查看>>
C - Common Subsequence
查看>>
如何以特定的时间间隔为图片添加动画效果?
查看>>
虚拟机mac 与主机的网络共享
查看>>
02 管理企业
查看>>
EventID 6398
查看>>
DNS服务器搭建
查看>>
页面生成周期中的两个Application池的详情小弟了解
查看>>
localhost与127.0.0.1的区别是什么?
查看>>
机器学习算法汇总:人工神经网络、深度学习及其它
查看>>
Android下Affinities和Task
查看>>
我们应该如何对待开源?——看完ssh有感
查看>>
启动Android模拟器报 “The connection to adb is down, and a severe error has occured.”的错误...
查看>>
activity跳转动画
查看>>
THE OVERARCHING PROCESS OF TEST DESIGN
查看>>
Linux 网络编程之 Select
查看>>
Gym 101194H 2016 ecfinal H题
查看>>
upper_bound()与lower_bound()的使用
查看>>
Aix项目_shell_rsh_01
查看>>
SOFARPC —— Generic Service (泛化调用) 解析
查看>>