我在组件中嵌套了单击事件处理程序:
class ListItem extends React.Component {
...
render() {
return (
<div onClick={this.save}>
...Content...
<span onClick={this.onDeleteClick}> (Delete)</span>
</div>
);
}
...
}
(这篇文章底部的完整的最小示例。)
该组件用作包含组件内的“列表项”。当我单击(Delete)
它时,它会按预期触发onDeleteClick
,这会对父组件进行回调,从而导致组件从父组件中删除。正如预期的那样,点击事件然后开始冒泡。但是,它会“向上”冒泡到父列表中的下一个组件。毕竟,删除处理程序已经删除了原始目标。
如果我e.stopPropagation()
在处理程序的顶部添加一个,onDeleteClick
它一切正常,但我只是想了解为什么单击事件被传递到一个完全不同的组件,只是为了确保那里没有任何其他确凿的证据.
我目前的理论是,挂起的事件队列以某种方式被索引到虚拟 DOM 中,如果您在事件处理程序期间改变虚拟 DOM,冒泡事件可能会传递到虚拟 DOM 中的错误组件。我本来希望冒泡事件根本不会触发,而不是在完全不同的组件上触发。
这是怎么回事?还有其他见解吗?这是一个有缺陷的设计吗?如果是,有什么替代方案的建议吗?
这是一个显示问题的最小示例:https ://codepen.io/mgalgs/pen/dRJJyB
这是固定版本:https ://codepen.io/mgalgs/pen/KqZBKp
“修复”的完整差异是:
--- orig.jsx
+++ new.jsx
@@ -32,6 +32,7 @@
}
onDeleteClick(e) {
+ e.stopPropagation();
this.props.onDeleteClick(e);
}
}