gpt4 book ai didi

Javascript 在旧浏览器中执行点击 html "image"

转载 作者:行者123 更新时间:2023-11-30 12:07:42 24 4
gpt4 key购买 nike

我正在尝试点击 <image>元素。我发现:

[3] Older versions had HTMLInputElement.click(), and HTMLButtonElement.click() only.

有人知道如何通过其他方式触发同一事件吗?

谢谢

编辑:.click() 适用于所有浏览器。但我需要在 Android 的 2.3 浏览器上执行此操作,它给了我:

01-10 21:19:18.375 4786-4786/com.example.victormilazzo.siganotifier E/Web Console: TypeError: Result of expression 'document.getElementById('btnLogin2').click' [undefined] is not a function. at undefined:1

使用下面的代码解决

正如我所说,旧浏览器仅支持输入或按钮元素上的 click() 方法。所以,我尝试了:

function simulateclick(){
var elem = document.getElementById('btnLogin2');
var evt = document.createEvent('MouseEvents');
evt.initMouseEvent('click', true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, elem);
elem.dispatchEvent(evt);
}
var btn = document.createElement('BUTTON');
btn.addEventListener('click', simulateclick);
btn.click();

PS.: 'btnLogin2' 是我试图点击的元素的 ID。这是一个<div> .

说明:我刚刚创建了一个按钮并添加了一个模拟点击事件的事件监听器

谢谢大家!

最佳答案

如果您的目标是较旧的浏览器,则只能在输入或按钮元素上附加点击事件。该问题可以通过使用 css 属性 background-image 设置按钮样式来解决。

  • 向按钮添加图像
  • background-color设置为white
  • 边框设置为

在代码示例中,您会看到这是如何工作的:

var clickCounter = 0;
var messageBox = document.getElementById("message");

function clickMe() {
clickCounter++;
messageBox.innerHTML = "Clicked " + clickCounter + " times";
}
button {
background-image: url(data:image/gif;base64,R0lGODlhEAAQAMQAAORHHOVSKudfOulrSOp3WOyDZu6QdvCchPGolfO0o/XBs/fNwfjZ0frl3/zy7////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAkAABAALAAAAAAQABAAAAVVICSOZGlCQAosJ6mu7fiyZeKqNKToQGDsM8hBADgUXoGAiqhSvp5QAnQKGIgUhwFUYLCVDFCrKUE1lBavAViFIDlTImbKC5Gm2hB0SlBCBMQiB0UjIQA7);
height: 70px;
width: 70px;
background-color: white;
border: none;
}
<button onclick="clickMe()"></button>
<p id="message">Click me</p>

编辑:

如您在 MDN 文档中所见,Android 浏览器不支持点击事件。 click documentation

关于Javascript 在旧浏览器中执行点击 html "image",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34710807/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com