如何从react.js元素中删除特定的事件侦听器

时间:2013-10-14 21:21:37

标签: javascript reactjs

我正在使用这个简单的渲染函数和几个处理程序:

render:function(){
        return (
            <div id="all-highlights" class="highlight-container" onMouseDown={this.drag} onMouseUp={this.dragEnd} onMouseMove={this.moving}>
                <div class="highlight">

                </div>
            </div>
        );
    }

在React.createClass函数中,使用类似:this.removeTheListener函数的东西,我如何删除特定的mouseMove函数?无论mouseMove函数的性能如何,我都知道它的资源很重,但我正在做的事情就是完美的事件。

是否可以仅删除特定的侦听器,然后一旦删除就将其添加回不同的时间点?

2 个答案:

答案 0 :(得分:9)

与React中的所有内容一样,关键是以声明方式思考。最简单的方法是存储一些与您是否要附加事件相对应的状态。 (你可能已经有了这样的旗帜!)然后你可以这样做:

onMouseMove={this.state.dragging ? null : this.moving}

然后简单地写

this.setState({dragging: true});

在您的mousedown处理程序中。

答案 1 :(得分:7)

在React中,如果要更改某些内容(属性,侦听器等),则应通过更新状态强制组件重新呈现。然后根据该状态进行渲染。

以下是一段适合您的代码:

var DraggableComponent = React.createClass({

  getInitialState: function() {
    return {
     dragging: false
    };
  },

  render: function(){
    var onDrag = this.state.dragging ? this.onDrag : null;
    return (
      <div
        className="highlight-container"
        onMouseDown={this.dragStart}
        onMouseUp={this.dragEnd}
        onMouseMove={onDrag}>
        <div className="highlight">
          {this.props.children}
        </div>
      </div>
    );
  },

  dragStart: function() {
    this.setState({dragging: true});
  },

  dragEnd: function() {
    this.setState({dragging: false});
  },

  onDrag: function() {
    // ...
  }

});