Closed
Description
TextInput event order are different for iOS and Android.
This inconsistency make certain operations hard to archive on Android:
- Detect backspace key on empty text input to delete the component. If only 1 character is left in the text, pressing backspace key will delete the text first before we process which key is pressed, which will make us assume that the text input is empty.
- Processing text on
change text event
beforeselection change event
can cause crash due to invalid selection.
Environment
Tested on Expo 25.0.0/0.52.0, but original issue happen in 0.53.3 as well, Likely exist in 0.54.0
Expected Behavior
I think iOS order of events make the most sense and I hope Android can follow the suit.
Actual Behavior
The event in question are onChangeText()
, onSelectionChange()
and onKeyPress()
.
On iOS, the events are in the following order:
- key press
- selection change
- change text
On Android, the events are in the following order:
- change text
- selection change
- onKeyPress (See (Android) Incorrect key reported from TextInput onKeyPress event #18262)