渲染组件时运行onClick函数

时间:2019-08-16 05:50:21

标签: javascript reactjs onclick mapping emoji

呈现组件时运行的onCLick处理程序,代码中是否有任何错误?

class MappedEmoji extends React.Component{
    render(){
        const data = this.props.emoji.map(emoji => {
            return(
                <span onClick={this.props.handleClick(emoji)}  className="myEmoji">{emoji}</span>
            )
            });

        return(
            <div> {data}</div>
        )
    }

}
class StickersComponent extends React.Component{
    constructor(props){
        super(props);
        this.state={
            Emoji:["?","?","?","?","?","?","?","?","?","?","?","?","?","?","?"],
        };
       this.handleClick = this.handleClick.bind(this);
    }
    handleClick(emoji){
        console.log(emoji);
    }
    render(){       
        return(
            <div className="stickers555">
                <div className="_emoji">
                {
                        <MappedEmoji emoji={this.state.Emoji}
                        handleClick = {this.handleClick}/>
                }
                </div>
            </div>

        )
    }
}
  ReactDOM.render(<StickersComponent />, document.getElementById('App'))
上面的

是完美呈现所有Emoji表情的代码,但是当onclick处理程序绑定到onClick函数时,它没有绑定或可能有其他问题。由于单击处理程序已绑定,因此渲染时我将在控制台中获取所有表情符号。

1 个答案:

答案 0 :(得分:0)

尝试作为回叫电话。

<span onClick={() => this.props.handleClick(emoji)}  className="myEmoji">

如果必须将参数传递给函数,并且不想立即调用它,则需要使用回调。

   onClick={ () => yourFunction(argument1) }