在下面的例子中,我有一个简单的<table>
,里面有一个复选框。我在 td、tr 和复选框上有点击事件。我希望能够单击复选框并停止冒泡到 td 和 tr。一个简单的“event.stopPropagation()”效果很好。
问题是,如果我想<label>
使用“htmlFor”将 a 连接到复选框,则单击标签时事件不会停止冒泡(即使单击复选框本身仍然按预期工作)。更奇怪的是,冒泡似乎以奇怪的顺序发生(就像最后收到复选框点击一样!)。
这是代码:
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/ (查看点击事件的控制台)