Я слышал, что передача функции стрелки в качестве опоры не идеальна, потому что она каждый раз создает новую функцию, которая приводит к проблемам с производительностью.Однако я не совсем уверен, как полностью отойти от них, как видно из приведенного ниже примера:
class Home extends Component {
onCardPress = (message) =>{
alert(message)
}
render(){
return(
<View>
<Card
onCardPress={this.onCardPress}
message="Hello world!"
/>
</View>
)
}
}
class Card extends Component {
render(){
const { onCardPress , message } = this.props;
return(
<TouchableOpacity
activeOpacity={0.8}
onPress={()=>{onCardPress(message)}}
/>
)
}
}
Я пытался изменить onPress
в Card
на onPress={onCardPress(message)}
, но я знаю, что это не работает, потому что я вызываю функцию, а не передаю объект функции в onPress
из TouchableOpacity
.Каков «правильный» способ или лучшая практика для удаления функции стрелки в TouchableOpacity
при возможности передачи параметра message
из родительского компонента Home
?