JavaScript事件传播在HTML Button子元素上不适用于Firefox。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript事件传播在HTML Button子元素上不适用于Firefox。相关的知识,希望对你有一定的参考价值。

我试图在html Button元素及其子元素上传递javascript函数,但是在Firefox上不触发子元素函数。

它在Chrome和Safari上运行良好。

在这里测试。

HTML块:

<div class="container p-5">
  <button onClick="sayButton();" class="btn btn-block btn-primary">
    <span class="badge badge-light" onClick="sayDiv(event)">Hello</span>
  </button>
</div>

JavaScript函数:

function sayButton() {
 alert("button");
}

function sayDiv(e) {
 e.stopPropagation();
 alert("div");
}

说Div功能不适用于Firefox。

的jsfiddle:https://jsfiddle.net/jainvabhi/nmp2L7ma/3/

Codepen:qazxsw poi

答案

我不确定Firefox是否允许您使用按钮元素作为父级。根据我的理解,按照按钮的https://codepen.io/jainvabhi/pen/VQNgZq,你不应该有互动的孩子。话虽如此,如果您将按钮更改为如下所示的div,它将起作用。

Content Model

<div class="container p-5"> <div onClick="sayButton();" class="btn btn-block btn-primary"> <span class="badge badge-light" onClick="sayDiv(event)">Hello</span> </div> </div>

如果这是用于生产应用程序,请在为此目的使用按钮以外的元素时考虑强大的Fiddle Fork

以上是关于JavaScript事件传播在HTML Button子元素上不适用于Firefox。的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript中的事件冒泡?事件传播的解释

JavaScript 停止事件传播(阻止事件冒泡)

再看《JavaScript高级程序设计》第13141720-25章

JavaScript系列之事件冒泡机制简介

事件的传播

HTML 学习笔记 JavaScript(事件)