3

我无法让我的 React 应用程序在移动 Safari 上以最佳方式工作。我的应用程序通常会在桌面上放置、发布、修补和删除,但在我的 iPhone 上不会这样做。我尝试在下面的 React 组件中添加“cursor:pointer”和 onTouchStart,但似乎没有任何效果。

 onSubmit(event) {
    const name = this.state.name;
    const instructor = cookies.get('instructor')._id;
    this.setState({
       submitted: true,
     });
    this.props.dispatch(actions.editCourse(name,this.props.match.params.cuid));
   }



  render() {
    if (this.state.submitted) {
       window.location.href = `https://young-mountain-65748.herokuapp.com /courses/${this.props.match.params.cuid}`;
    }
return (
    <div className="container">
        <div className="field-line">
          <label htmlFor="coursename">New Course Name:</label>
          <input
            id="coursename"
            name="coursename"
            value={this.state.name}
            onChange={this.updateName}
          />
        </div>
    </div>
    <div className="edit-course-buttons">
      <button
        className="edit-course"
        onClick={this.onSubmit}
        onTouchStart={this.onSubmit}>
        Edit Course
      </button>
    </div>
  </div>
);

} }

4

1 回答 1

0

我在 iOS 设备上也遇到了同样的问题。能够通过将 onClick 替换为触摸事件来克服这些问题。查看有关 ReactJS 中触摸事件的文档。您可以使用 onTouchStart 代替 onClick 看看它是否有效!所以你的按钮应该是这样的:

<button onTouchStart="{this.onSubmit}" onclick = "void(0)" ...>
</button>

我已按照此处onClick接受的答案中的建议添加。

https://facebook.github.io/react/docs/events.html#touch-events

检查类似的问题,根据投票最多的答案,您需要使用 touchevent 并将cursor: pointer;css 添加到与 click 事件关联的元素中。

于 2017-08-23T03:49:46.843 回答