react中的onMouseDown事件不会触发状态更改,但onClick会触发

Sim*_*aur 6 reactjs

JSX部分看起来像这样:

<span className="header_srh_i_c" onMouseDown={this.toggleSearchbar}>
    <i className="fa fa-search"
        id="searchButton"
        name="searchButton"
     />
 </span>
Run Code Online (Sandbox Code Playgroud)

同一组件中的函数如下所示:

toggleSearchbar(event){
    const eventType = event.type;
    if(this.state.showSearch && this.props.q && length(this.props.q) > 0){
      this.toggleSearching();
    }else{
      console.log("state after", this.state.showSearch)  //false

      this.setState({showSearch:!this.state.showSearch},function (event) {
      console.log("state after", this.state.showSearch) //false
      })
    }
  }
Run Code Online (Sandbox Code Playgroud)

false执行后状态仍为事件

this.setState({showSearch:!this.state.showSearch},function (event) {
          console.log("state after", this.state.showSearch) //false
          })
Run Code Online (Sandbox Code Playgroud)

但是,如果我使用onClick而不是,它的工作正常onMouseDown

Ole*_*yba 1

尝试

this.setState(prev => ({showSearch: !prev.showSearch}), function(){.....})
Run Code Online (Sandbox Code Playgroud)

代替

this.setState({showSearch:!this.state.showSearch},function (event) {
      console.log("state after", this.state.showSearch) //false
      })
Run Code Online (Sandbox Code Playgroud)