首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用document.querySelector()触发事件click()不起作用,但是从控制台触发CSS事件单击()可以

使用document.querySelector()触发事件click()不起作用,但是从控制台触发CSS事件单击()可以
EN

Stack Overflow用户
提问于 2021-11-21 00:02:42
回答 1查看 152关注 0票数 0

使用click()触发事件click()不起作用,但从控制台触发CSS事件click()工作正常,如下所示:

代码语言:javascript
运行
复制
$0.click(); // Works Ok

$0引用与document.querySelector()相同的元素

代码语言:javascript
运行
复制
const element = document.querySelector('.red')
element.click(); // Not Works

element

代码语言:javascript
运行
复制
<span color="foreground" class="red">Red</span>

$0

代码语言:javascript
运行
复制
<span color="foreground" class="red">Red</span>

如何使用document.querySelector()单击元素

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-21 00:50:18

起作用了吗?

首先,请注意,在控制台中触发$0.click()不是CSS,而是Javascript。

另外,使用querySelector调用元素,然后触发click方法,效果很好。下面是一个基本的例子:

代码语言:javascript
运行
复制
setInterval(() => {
  document.querySelector('.red').click()
}, 1000)
代码语言:javascript
运行
复制
<span class="red" onclick="console.log('clicked')">Text in a span</span>

为什么它会失败

您不会遇到不同的情况,您的代码不像您所期望的那样工作

1-您可以在页面加载完成之前调用您的脚本。在这种情况下,对document.querySelector的引用将找不到元素,而是返回null而不是元素。但是当这种情况发生时,我们会在控制台中得到一个错误。

2-页面中有几个元素,类为"red“。然后,您可能正在单击另一个元素。在这种情况下,控制台中什么都不会出现。

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

https://stackoverflow.com/questions/70050854

复制
相关文章

相似问题

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