picostitch
crafting (and) JavaScript

KeyboardAvoidingView the Missing Docs

If you are struggling with React Native's KeyboardAvoidingView and it does not behave as you expect, the most probable reason is some flex layout issue. I highly recommend reading KeyboardAvoidingView not working properly? Check your Flexbox Layout first by Nick Yang.

Besides that I also think there is quite some more stuff that is hidden in the code and not in the docs. I am just collecting the stuff here, mainly so I can look it up again.

behavior prop explained

The behavior prop is not well explained in the React Native docs.

Allow me to go through these attributes for the prop behavior one by one.

I am considering the object for which our keyboard gets called.

"padding": The component goes to a higher position once the keyboard pops up. It is advised to use padding when there are not many components on the screen otherwise the layout might break where the Component may overlap with the components above it.(note: the components above it would also be moved up..but in order to adjust the Views there might be an overlap). Note: Here Both things : the TextInput and the components may get overlapped.

"position": the entire View containing TextInput would be moved up and there is a chance that some of the components above may not be available/visible on the top of the screen i.e. would be cut off from the top of the screen being the upper bound.

"height": generally used with keyboardVerticalOffset. It is used to resize the View of the screen once the keyboard pops up. Might as well lead to overlapping in an attempt to resize the screen. Here, the TextInput would be overlapping above the component above it in case of an overlap.

by @ckaus on stackoverflow

Not the Best Solution!?

In the same thread Matt Way states:

In my opinion, this component should be scrapped though, in favour of helper functions that would return keyboard heights over time, so you could apply your own style ideas directly based on keyboard visibility.

link to stackoverflow.

Which I find a quite accurate statement, because

  • this component caused a lot of trouble for me, especially when layouts get more complex.
  • It behaves differently on iOS and Android and
  • it has a lot of (open) issues in the react-native repo (96 closed and 25 open as of December 2020).

"Why didn't you contribute to the docs?"

A totally valid question, and absolutely the right one to ask. I am listing it here, because I have thought about that too.

To be honest, there are couple of reasons:

  • I too lazy going through a CLA process,
  • I also hesitate a bit doing that with a company like facebook
  • writing on this blog is much faster.

Sorry if none of those reasons are good enough. They are just mine.