在下面的示例中,我有一个简单的<table>
,其中有一个复选框。我在td,tr和复选框上有点击事件。我希望能够点击复选框并停止冒泡到td和tr。一个简单的“event.stopPropagation()”效果很好。React - 我无法停止在表格中点击标签的传播
问题是,如果我想使用“htmlFor”将复选框<label>
连接到该复选框,则单击标签时事件不会停止冒泡(即使点击复选框本身仍可按预期工作) 。更奇怪的是,冒泡似乎以奇怪的顺序发生(如最后一次收到复选框点击!)。
下面的代码:
var Hello = React.createClass({
func1(e){
console.log('tr was clicked')
},
func2(e){
console.log('td was clicked')
},
func3(e){
e.stopPropagation();
console.log('Checkbox was clicked')
},
render: function() {
return <table>
<tbody>
<tr onClick={this.func1}>
<td onClick={this.func2}>
<input id="thing" type="checkbox" onClick={this.func3} />
<label htmlFor="thing"> label for checkbox</label>
</td>
</tr>
</tbody>
</table>;
}
});
ReactDOM.render(
<Hello name="World" />,
document.getElementById('container')
);
......而这里的小提琴: https://jsfiddle.net/69z2wepo/52785/ (查看控制台,点击事件)
点击该标签实际生成*两个*事件:一个是点击标签和一个(隐含)点击复选框。您只处理复选框,但不处理标签。这是一个简单的HTML + JS示例:https://jsfiddle.net/zh55jwzv/(这不是特定的反应)。 –