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>
相关推荐
看到我请叫我铁锤2 小时前
vue3中THINGJS初始化步骤
前端·javascript·vue.js·3d
q***25212 小时前
SpringMVC 请求参数接收
前端·javascript·算法
谢尔登3 小时前
defineProperty如何弥补数组响应式不足的缺陷
前端·javascript·vue.js
T***u3334 小时前
前端框架在性能优化中的实践
javascript·vue.js·前端框架
jingling5555 小时前
vue | 在 Vue 3 项目中集成高德地图(AMap)
前端·javascript·vue.js
油丶酸萝卜别吃5 小时前
Vue3 中如何在 setup 语法糖下,通过 Layer 弹窗组件弹出自定义 Vue 组件?
前端·vue.js·arcgis
芳草萋萋鹦鹉洲哦14 小时前
【elemen/js】阻塞UI线程导致的开关卡顿如何优化
开发语言·javascript·ui
1***s63214 小时前
Vue图像处理开发
javascript·vue.js·ecmascript
槁***耿14 小时前
JavaScript在Node.js中的事件发射器
开发语言·javascript·node.js
一叶茶14 小时前
移动端平板打开的三种模式。
前端·javascript