Roh*_*thi 5 react-native touchableopacity
我有一个简单的图标按钮如下:
class SideIcon extends Component {
render() {
return (
<TouchableOpacity onPress={console.log('puff')} style={styles.burgerButton}>
<Icon name="bars" style={styles.burgerIcon}/>
</TouchableOpacity>
);
}
}
Run Code Online (Sandbox Code Playgroud)
它来自以下组件:
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>
);
}
});
Run Code Online (Sandbox Code Playgroud)
但onPress 对TouchableOpacity 从未工程.我哪里错了?虽然它在组件加载期间显示控制台语句.
您应该绑定一个调用代码的函数.
例如:
<TouchableOpacity onPress={() => console.log('puff')} style={styles.burgerButton}>
<Icon name="bars" style={styles.burgerIcon}/>
</TouchableOpacity>
Run Code Online (Sandbox Code Playgroud)
更好的方法是给它一个组件函数的引用
class SideIcon extends Component {
handleOnPress = () => {
console.log('puff')
}
render() {
return (
<TouchableOpacity onPress={this.handleOnPress} style={styles.burgerButton}>
<Icon name="bars" style={styles.burgerIcon}/>
</TouchableOpacity>
);
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
23401 次 |
| 最近记录: |