gpt4 book ai didi

javascript - 在 props 中传递函数是未定义的

转载 作者:搜寻专家 更新时间:2023-11-01 04:35:21 24 4
gpt4 key购买 nike

当试图将函数传递给子组件时,该函数未定义。实际上我什至不能直接在我的类里面执行它。你会认为有错字吗?

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 />没有prop名为 mylog在任何其他位置,它将是未定义的。

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 - 在 props 中传递函数是未定义的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42527211/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com