[英]Textinput (React Native - Android) - Support onKeyPreIme
在本機代碼(java)中,我可以使用handle onKeyPreIme
創建TextInput
像這樣
com/myapp/CustomEditText.java
package com.myapp;
import android.content.Context;
import android.util.AttributeSet;
import android.view.KeyEvent;
import android.widget.EditText;
public class CustomEditText extends EditText {
public CustomEditText(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public boolean onKeyPreIme(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
return true;
}
return false;
}
}
XML
// res/layout/activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<com.myapp.CustomEditText
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/someid"
android:layout_height="wrap_content"
android:layout_width="match_parent"
/>
MainActivity.java
// com/myapp/MainActivity.java
package com.myapp;
import android.os.Bundle;
import com.facebook.react.ReactActivity;
public class MainActivity extends ReactActivity {
...
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); //this line test TextInput
...
}
}
在TextInput
做反應原生支持嗎?
感謝您的幫助。
編輯:我的目標是在顯示鍵盤時停止按下。 使用onKeyPreIme
可以輕松使用onKeyPreIme
。 我嘗試使用React原生的@Override onBackPress
和BackHandler
,但也不起作用。
// MainActivity.java
@Override
public void onBackPressed() {
return;
}
鍵盤顯示時此代碼不起作用。
const blackBack = () => true;
Keyboard.addListener('keyboardDidShow', () => {
BackHandler.addListener('hardwareBackPress', blackBack)
});
Keyboard.addListener('keyboardDidHide', () => {
BackHandler.removeListener('hardwareBackPress', blackBack)
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.