首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Javascript "onmousedown“没有触发

Javascript "onmousedown“没有触发
EN

Stack Overflow用户
提问于 2020-08-17 13:22:37
回答 3查看 56关注 0票数 2

我正在尝试对元素"onmousedown“运行一个函数。代码如下:

代码语言:javascript
复制
<label class="switch">
     <input type="checkbox" onmousedown="console.log('Run the function'); 
            manageBook(this);"  id="element-id-52"  data-mode= "offx">
     <span class="slider round"></span>
</label>

但是当我单击滑块时,既看不到console.log()消息,也看不到函数正在运行。知道是什么原因造成的吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-08-17 13:28:06

尝试将侦听器添加到标签中,而不是添加到输入元素中。

代码语言:javascript
复制
<label
  class="switch"
  onmousedown="console.log('Run the function'); manageBook(this);
>
票数 0
EN

Stack Overflow用户

发布于 2020-08-17 13:29:32

由于鼠标按下仅在将侦听事件的输入元素上,如果将鼠标向下移动到<label class="switch">,则来自子元素的事件也将向上冒泡到该元素,并覆盖所有3个元素的向下事件

票数 1
EN

Stack Overflow用户

发布于 2020-08-17 13:36:38

Input onmousedown运行良好,您可以将侦听器移动到父块以获得成功

代码语言:javascript
复制
const manageBook=(input)=>{
    console.log('manage book', input);
};

const withSpan=(a)=>{
    console.log('with span', a);
};
代码语言:javascript
复制
<label class="switch" onmousedown="withSpan(this);">
    <input type="checkbox" onmousedown="console.log('Run the function');manageBook(this);" id="element-id-52" data-mode="offx">
    <span class="slider round">aaaa</span>
</label>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63444971

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档