【发布时间】:2019-04-02 21:12:44
【问题描述】:
我想在 array.map 函数中添加事件监听器 onTouchStart、Move 和 End 到 img 标记,因此它只捕获一个事件监听器(onTouchStart),但如果我将此监听器设置为 div 且 class="header- added-heroes”所有 3 个侦听器都工作,我阅读了有关将 'this' 绑定到 array.map 及其仅捕获 onTouchStart 的信息,我将不胜感激有关此问题的任何信息。
{this.props.addedHeroes.map( function(el) {
return (<a name={el.link} key={uniqueId()} className="heroes__link">
<div className="hero"> {console.log(' map this : ', this === that)}
{
<img className="hero__image"
onTouchStart={this.onTouchStart}
onTouchMove={this.handleMove}
onTouchEnd={this.onTouchEnd}
src={el.image}
/>
}
</div>
</a>);
}, this )}
完整代码:
import React from "react";
import uniqueId from "lodash/uniqueId";
import HeroCounter from "../../images/HeroCounter.svg";
class HeaderAddedHeroes extends React.Component {
state = {
heroes: [1, 2, 3, 4],
showCloseButton: 0
};
constructor(props) {
super(props);
this.onTouchStart = this.onTouchStart.bind(this);
this.onTouchEnd = this.onTouchEnd.bind(this);
this.handleMove = this.handleMove.bind(this);
}
handleMove() {
console.log('moved');
this.setState({ showCloseButton: 1 })
}
onTouchStart() {
console.log('started');
this.setState({ showCloseButton: 2 })
}
onTouchEnd() {
console.log('ended');
this.setState({ showCloseButton: 3 })
}
render() { var that = this;
return (
<header className="header-added-heroes"> { console.log(' this : ', that)}
<div className="header-added-heroes"
onTouchMove={this.handleMove}
onTouchStart={ this.onTouchStart }
onTouchEnd={this.onTouchEnd}>
{ this.state.showCloseButton }
</div>
<div className="heroes">
{this.props.addedHeroes.map( function(el) {
return (<a name={el.link} key={uniqueId()} className="heroes__link">
<div className="hero"> {console.log(' map this : ', this === that)}
{
<img className="hero__image"
onTouchStart={this.onTouchStart}
onTouchMove={this.handleMove}
onTouchEnd={this.onTouchEnd}
src={el.image}
/>
}
</div>
</a>);
}, this )}
</header>
);
}
}
【问题讨论】:
-
所以问题是
onTouchMove和onTouchEnd没有被解雇?为什么你需要console.log内部渲染?请删除它,并为地图this.props.addedHeroes.map((el) =>{制作箭头功能@ -
是的,onTouchMove和onTouchEnd都没有触发,忘了说最初是用箭头函数启动的,而且也只捕获了onTouchStart
标签: reactjs touch touch-event