javascript – 在props中传递函数是未定义的
作者:互联网
尝试将函数传递给子组件时,该函数未定义.实际上我甚至不能直接在我班上执行它.你觉得有拼写错误吗?
class FriendsPage extends Component {
constructor(props){
super(props);
this.mylog = this.mylog.bind(this);
}
mylog(){
console.log("test debug");
}
renderItem(item) {
return (<User friend={item} key={item.id} mylog={this.mylog}/>);
}
class User extends Component {
constructor(props){
super(props);
}
render() {
this.props.mylog(); // <== This is undefined
...
}
解决方法:
工作良好.但是,如果您尝试渲染< User />没有在任何其他位置命名为mylog的prop,它将是未定义的.
class FriendsPage extends React.Component {
constructor(props) {
super(props);
this.mylog = this.mylog.bind(this);
}
mylog() {
console.log("test debug");
}
render() {
return ( < User mylog = {
this.mylog
}
/>);
}
}
class User extends React.Component {
constructor(props) {
super(props);
}
render() {
this.props.mylog();
return <h1 > Hello < /h1>;
}
}
ReactDOM.render( < FriendsPage / > , document.getElementById('root'));
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
<div id="root"></div>
标签:javascript,react-native,react-native-android 来源: https://codeday.me/bug/20190710/1428443.html