原版 javascript -
document.addEventListener("click", function(){ alert('click fired');});
Angular 为 2 + -
@HostListener('window: click', ['$event'])
public iosSafariClick(e: any): void {
alert('event fired');
}
此方法在 iPad 上的 IOS safari 上均无效。
除非我点击某个按钮、超链接或任何可操作的项目,否则不会触发 Click 事件。
我的目标是在“div 元素”上触发 blur 事件。
为此,我试图检查是否在 HTML 正文上触发了任何点击事件,并检查它是否在“div 元素”上。
HTML >
<html>
<body>
<div id= 'menu'>123...</div>
</body>
</html>
Angular 组件 > typescript >
@HostListener('window: click', ['$event'])
public iosSafariClick(e: any): void {
if(e.target.id !== 'menu'){
this.menu = false; // to close menu
}
}
有没有办法使用 javascript 或 Angular 来克服这个障碍?
Best Answer-推荐答案 strong>
使用基于触摸的设备时,向浏览器发出的事件是不同的。
它还为开发人员提供了准确的用例,以便围绕其进行设计和开发。
我会假设既然没有鼠标那么就不会有点击事件。
取自 MDN:
为了为基于触摸的用户界面提供高质量的支持,触摸事件提供了解释触摸屏或触控板上的手指(或触控笔)事件的能力。
尝试使用:
document.addEventListener('touchstart', () => console.log('touch called'));
您始终可以选择使用 function () {} 而不是 () => {}
查看完整详情:https://developer.mozilla.org/en/docs/Web/API/Touch_events
关于javascript - Window.click 事件不会在 IOS Safari 上触发 - 仅限 JavaScript,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/43335183/
|