次のようなシンプルなアイコンボタンがあります。
class SideIcon extends Component {
render() {
return (
<TouchableOpacity onPress={console.log('puff')} style={styles.burgerButton}>
<Icon name="bars" style={styles.burgerIcon}/>
</TouchableOpacity>
);
}
}
次のコンポーネントから呼び出されます:
export default test = React.createClass({
getInitialState: function() {
return {
isModalOpen: false
}
},
_openModal() {
this.setState({
isModalOpen: true
});
},
_closeModal() {
this.setState({
isModalOpen: false
});
},
render() {
return (
<View style={styles.containerHead} keyboardShouldPersistTaps={true}>
**<SideIcon openModal={this._openModal} closeModal={this._closeModal} />**
<Text style={styles.logoName}>DareMe</Text>
<SideBar isVisible={this.state.isModalOpen} />
</View>
);
}
});
ただし、onPress
のTouchableOpacity
は機能しません。どこがいけないの?ただし、コンポーネントのロード中にコンソールステートメントが表示されます。
コードを呼び出す関数をバインドする必要があります。
例えば:
<TouchableOpacity onPress={() => console.log('puff')} style={styles.burgerButton}>
<Icon name="bars" style={styles.burgerIcon}/>
</TouchableOpacity>
より良い方法は、コンポーネント関数への参照を与えることです
class SideIcon extends Component {
handleOnPress = () => {
console.log('puff')
}
render() {
return (
<TouchableOpacity onPress={this.handleOnPress} style={styles.burgerButton}>
<Icon name="bars" style={styles.burgerIcon}/>
</TouchableOpacity>
);
}
}