Reactjs touchevents无法正常工作

时间:2015-03-13 15:35:39

标签: reactjs ontouchevent react-router

我正试图在触摸式水龙头上触发课程。使用onClick,它在桌面上工作正常,但使用onTap / onTouchStart / onTouchEnd时,事件不会被触发。我在渲染组件之前运行React.initializeTouchEvents(true)。点击处理程序位于div元素上,我已设置cursor: pointer。我正在使用lonovo yoga 2 pro和iPad进行测试。另外我使用react router。 任何人都知道它为什么不起作用?

初​​始化:

React.initializeTouchEvents(true)
Router.run(routes, Router.HistoryLocation, function (Handler) {
  React.render(<Handler data={dummyData} />, document.getElementById('app'));
});

组件:

var Transaction = React.createClass({
  getInitialState: function(){
    return ({showDetails: false})
  },
  toggleDetails: function(e){
    e.preventDefault()
    this.setState({showDetails: !this.state.showDetails})
  },
  render: function(){
    var itemClasses = "pl-transaction-item pl-transaction-status-"+this.props.data.status
    return (
      <li className={this.state.showDetails ? itemClasses + " pl-active" : itemClasses} >
        // here is the touch event listener
        <div className="pl-transaction-item-header" onTap={this.toggleDetails} onTouchEnd={this.toggleDetails}>
          <img src={this.props.data.img} alt="" /><span>name: {this.props.data.name}</span><span>status: {this.props.data.status}</span><span>date: {this.props.data.date}</span>
        </div>
        <div className="pl-transaction-item-details">
          <img src={this.props.data.img} alt="" />
          <ul>
            <li>name: {this.props.data.name}</li>
            <li>status: {this.props.data.status}</li>
            <li>date: {this.props.data.date}</li>
            <li><button>OK</button></li>
          </ul>
        </div>
      </li>
    )
  }
})

1 个答案:

答案 0 :(得分:2)

根据http://facebook.github.io/react/docs/events.html React没有onTap事件监听器。

因此,对于onTap,您可能希望尝试在componentDidMount生命周期中绑定onTap事件,如http://facebook.github.io/react/tips/dom-event-listeners.html中所做的那样