其他分享
首页 > 其他分享> > 适用于Android的TextInput上的onKeyPress方法

适用于Android的TextInput上的onKeyPress方法

作者:互联网

我一直试图在react-native中的TextInput中捕获键盘的事件.

通过阅读组件的doc(https://facebook.github.io/react-native/docs/textinput.html),我注意到了onKeyPress函数,它完全符合我的需要.但它仅被标记为ios.我没有找到任何关于android解决方法的内容,除了这个问题(https://github.com/facebook/react-native/issues/1882)现在几个月都处于非活动状态…

我需要做的是在按下Backspace时调用一个特定的方法,看起来它现在只能用于ios …

你们知道任何解决方法吗?

提前致谢 :)

解决方法:

我也遇到过这个问题.我可以告诉你,我做了什么.它不优雅,但它会完成这项工作,直到它也为Android实现.

在Android中,您可以在活动中使用handle key events.此外,你可以send events to JavaScript.这就是你需要的一切.

在js文件(例如componentDidMount)中添加监听器.

DeviceEventEmitter.addListener('onKeyPressed', yourFunction)

在您的MainActivity中添加这样的内容.

public boolean onKeyUp(int keyCode, KeyEvent event) {
   WritableMap params;
   // params.put something
   // filter only Backspace events if you wish etc.
   reactContext.getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
                           .emit("onKeyPressed", params);
}

每按一次键就会发送一次.不要忘记删除监听器(例如componentDidUnmount或不再需要它时).此外,如果您有多个TextInput,请跟踪焦点,以免混淆.

希望这可以帮助.

标签:onkeypress,textinput,android,react-native
来源: https://codeday.me/bug/20190828/1752964.html