最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - onClick called on render - Stack Overflow

programmeradmin2浏览0评论

When my application renders the function contained within my onClick event is invoked without reason. I have looked around at a few other posts and implemented their suggestion but without success.

My function

login = () => {
        this.props.login();
    };

onClick event inside an tag

<a style={{cursor: 'pointer'}} onClick={ () => this.login }> Log In </a>

When my application renders the function contained within my onClick event is invoked without reason. I have looked around at a few other posts and implemented their suggestion but without success.

My function

login = () => {
        this.props.login();
    };

onClick event inside an tag

<a style={{cursor: 'pointer'}} onClick={ () => this.login }> Log In </a>
Share Improve this question asked Oct 17, 2018 at 18:10 Richard PayneRichard Payne 3032 gold badges4 silver badges17 bronze badges 1
  • From that code, you don't really seem to be calling the function at all, there would even no reason for using an arrow function in jsx, as it is already bound... – Icepickle Commented Oct 17, 2018 at 18:14
Add a ment  | 

4 Answers 4

Reset to default 6

You need to pass your lambda like this:

<a style={{cursor: 'pointer'}} onClick={ () => this.login() }> Log In</a>

Note the parenthesis. As you have it now the function is automatically invoked when the script runs/your ponent renders.

It is also worth noting that using JSX lambdas can cause performance problems because it creates a new function on every render. You could do the following instead to prevent the new function generation.

class MyComp extends React.Component {
  constructor(props) {
    super(props);
    this.login = this.login.bind(this);
  }

  public function login(event) {
    // do something
  }

  render() {
    return(
      <a onClick={this.login}>Log In</a>
    );  
  }

}

Instead of just passing a reference to the click handler, you're passing an arrow function which is being invoked which is in turn calling the login function.

This should give you what you're after:

<a style={{cursor: 'pointer'}} onClick={ this.login }> Log In </a>

Check out the react handling events docs

Because your syntax is wrong. Correct syntax is:

<a style={{cursor: 'pointer'}} onClick={this.login}> Log In </a>

Try making the login function respond to an event login = (event) => {, and adding event.preventDefault()

Also, I'm not sure if it'd actually matter, or it's a stylistic thing, but you could just try onClick={this.login}

发布评论

评论列表(0)

  1. 暂无评论