我正在基于这些文档在安卓中开发一个自定义的原生RN UI组件:https://reactnative.dev/docs/native-components-android
该组件在安卓中扩展了TextView,以便在Javascript中公开一些功能(例如,文本选择,简单的HTML样式)。
我面临的问题是,我似乎无法让文本样式正常工作。假设我的组件名为CustomTextView
在React Native中,我希望我能做到:
<CustomTextView style={{color: 'red'}} text="blah"/>这将以黑色而不是红色显示文本blah。如何在Android中继承React Native的文本样式?其他样式规则(例如width、height)可以正常工作。
下面是我用Java语言实现的CustomTextView
CustomTextViewManager.java
public class CustomTextViewManager extends SimpleViewManager<TextView> {
public static final String REACT_CLASS = "RCTCustomTextView";
@Override
public String getName() { return REACT_CLASS; }
@Override
public TextView createViewInstance(ThemedReactContext context){
TextView view = new TextView(context);
view.setTextIsSelectable(true);
return view;
}
@ReactProp(name = "text")
public void setText(TextView view, String text) {
Spanned spanned;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
spanned = Html.fromHtml(text, Html.FROM_HTML_MODE_COMPACT);
} else {
spanned = Html.fromHtml(text);
}
view.setText(spanned);
}
}以下是复制此问题的repo的链接:https://github.com/nsantacruz/CustomTextViewTest
发布于 2020-11-27 06:20:45
我没有找到任何文档,但对我来说,将flex: 1添加到样式中很有帮助。
结果代码应该如下所示:
<CustomTextView
style={{
color: 'red',
flex: 1,
}}
text="blah"
/>https://stackoverflow.com/questions/60954541
复制相似问题