如何解决(React Native) 组件异常 - 文本字符串必须在 <Text> 组件中呈现
我正在用 React Native 开发一个应用程序,我有一些适用于 Web 和 iOS 的代码,但不适用于 Android。我不断收到标题中所述的错误,我不知道为什么......基本上该函数采用一个布尔数组,并返回这些标志所代表内容的图形表示(密码策略)。错误标志返回红色文本,真实标志返回绿色文本。应用程序编译并且在函数运行之前不会崩溃。请指教。
function displayPwPolicy(flags) {
var policies = [
"Be 8~256 characters long","Have uppercase character(s)","Have lowercase character(s)","Have numerical character(s)","Have special character(s)","Have no invalid characters"
]
return (
<View>
<Text style={styles.homePwPolicy}>*Your password must:</Text>
{
policies.map( (policy,i) =>
<Text key={'policy00' + i} style={{ color: flags[i] ? 'green' : 'red' }}>
{(flags[i] ? '✔':'✘') + '\t ' + policy}
</Text>
)
}
</View>
)
}
调用堆栈:https://photos.app.goo.gl/1G2JKUiYJqsLVHoz5
编辑 1: 这是函数调用。如果删除该行,该应用程序可以正常工作
<TextInput
style = {styles.homeInput}
value = {userLast}
placeholder = 'Last Name'
onChangeText = {last => setUserLast(last)}
/>
{ pwPolicyShown && displayPwPolicy(pwPolicyFlags) }
<TouchableOpacity style={styles.homeButtons}>
<Text style={styles.homeButtonText}>
CREATE ACCOUNT
</Text>
</TouchableOpacity>
解决方法
感谢 github 上 dulmandakh 的另一个 post 解决了这个问题。问题在于函数调用的条件渲染。如果不与比较运算符配对,某些平台显然会尝试呈现正在评估的变量。必须将“pwPolicyShown”更改为“pwPolicyShown == true”。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。