我发现Javascript焦点和模糊事件在安卓浏览器上连接到窗口、文档或正文时无法正确启动。
我写了一个简单的测试脚本,它在桌面浏览器上正常工作,但在Android股票浏览器、Dolphin和Opera手机上失败:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=0" />
<title>Focus test</title>
<script type="text/javascript">
window.onfocus = function() {
document.getElementById('console').innerHTML += '<div>Focus event handler fired.</div>';
};
window.onblur = function() {
document.getElementById('console').innerHTML += '<div>Blur event handler fired.</div>';
};
</script>
</head>
<body>
<input id="test" name="test" />
<div id="console"></div>
</body>
</html>
有趣的是,如果表单输入获得焦点,事件处理程序就会触发,而在blur上,blur事件处理程序会触发两次。
有人对此有好的解决方案或变通方法吗?
编辑:预期结果是,如果我更改浏览器选项卡,或更改到另一个应用程序,模糊事件应该触发,如果我返回浏览器选项卡,焦点事件应该触发(这就是它在桌面上的工作方式)
我相信轮询文档的焦点状态可能正是您想要的。每500毫秒轮询一次并不昂贵,而且可以满足您的需要。如果你想要文档焦点变化的几乎即时警报,你可以尝试100ms之类的方法。
let prevStateIsFocused = null // used to ensure that there is only one execution of a function for either the document focused or not
setInterval(() => {
if(document.hasFocus()){
if(prevStateIsFocused !== true){
console.log('window is focused')
// execute some function here ...
}
prevStateIsFocused = true
}else{
if(prevStateIsFocused !== false){
console.log('window has lost focused, blurred')
// execute some function here ...
}
prevStateIsFocused = false
}
}, 500)
演示:https://jsfiddle.net/sanjaydookhoo/1h7gncaf/
我刚刚在运行jellybean的Galaxy Nexus上测试了你的代码(我所有的),这个代码运行得很好,两个事件只触发一次。
document.getElementById('test').onfocus = function() {
document.getElementById('console').innerHTML += '<div>Focus event handler fired.</div>';
};
document.getElementById('test').onblur = function() {
document.getElementById('console').innerHTML += '<div>Blur event handler fired.</div>';
};
可能是你瞄准了这个窗口,在大多数移动设备上,这个窗口本身通常不会"模糊"。确保直接要求元素报告其自身的模糊和聚焦事件。
编辑:此外,在应用事件侦听器之前,请确保您正在等待DOM准备就绪。