devicemotion 或者 deviceorientation在window.addEventListener 事件中不生效,没有输出内容

问题:devicemotion 或者 deviceorientation 在window.addEventListener 事件中不生效,没有输出内容

原因:

1、必须在Https协议下才可使用

2、必须用户手动点击click事件中调用 ,进行权限申请

源码:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=375,user-scalable=0">
    <title>deviceorientation</title>
</head>
<body>
 
<button onclick="start()">start</button>
<script>
    (function () { var script = document.createElement('script'); script.src="https://cdn.jsdelivr.net/npm/eruda"; document.body.appendChild(script); script.onload = function () { eruda.init() } })();
    
    function start(){
        if(!DeviceMotionEvent){
            console.error('暂时不支持')
        }else{
            if(
                DeviceMotionEvent.requestPermission
            ){
                DeviceMotionEvent.requestPermission().then(permissionState => {
                    console.log(permissionState)
                    if (permissionState === 'granted') {
                        // window.addEventListener('devicemotion', function(e) { console.log('devicemotion', e)}, true);
                        window.addEventListener('deviceorientation', function(event) { console.log('deviceorientation', event) ; console.log(`${event.alpha} : ${event.beta} : ${event.gamma}`);}, true);
                    }
                }).catch((err) => {
                    console.error(err);
                });
            }else{
                // window.addEventListener('devicemotion', function(e) { console.log('devicemotion', e)}, true);
                window.addEventListener('deviceorientation', function(event) { console.log('deviceorientation', event) ; console.log(`${event.alpha} : ${event.beta} : ${event.gamma}`);}, true);
            }
        }
    }
    window.onload=function(){
        start() //此处调用无效,没有内容输出
    }
</script>

</body>
</html>
相关推荐
m0_4592524611 分钟前
fastadmin动态渲染统计信息
开发语言·前端·javascript·php
该怎么办呢22 分钟前
Source/Core/Matrix4.js
前端·javascript
该怎么办呢1 小时前
Source/Core/Event.js
开发语言·javascript·ecmascript·cesium
赵锦川2 小时前
大屏比例缩放
前端·javascript·html
该怎么办呢2 小时前
Source/Core/DeveloperError.js
开发语言·javascript·ecmascript
weixin_462901973 小时前
ESP32 LED控制代码解析
javascript
小张会进步3 小时前
数组:二维数组
java·javascript·算法
Dxy12393102163 小时前
js如何把字符串转数字
开发语言·前端·javascript
爱写bug的野原新之助3 小时前
爬虫之补环境:加载原型链
前端·javascript·爬虫
haorooms3 小时前
Promise.try () 完全指南
前端·javascript