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>
相关推荐
小福气_5 分钟前
自定义组件 vue3+elementPlus
前端·javascript·vue.js
程序员博博6 分钟前
这才是vibe coding正确的打开方式 - 手把手教你开发一个MCP服务
javascript·人工智能·后端
是谁眉眼21 分钟前
vue环境变量
前端·javascript·vue.js
鹏北海-RemHusband22 分钟前
Vue 组件解耦实践:用回调函数模式替代枚举类型传递
前端·javascript·vue.js
用户66006766853923 分钟前
斐波那契数列:从递归到缓存优化的极致拆解
前端·javascript·算法
NuLL24 分钟前
异步并行任务执行工具
javascript
海上彼尚26 分钟前
vite+vue3 ssg预渲染方案
前端·javascript·vue.js
NuLL31 分钟前
异步互斥锁
javascript
八荒启_交互动画37 分钟前
【基础篇007】GeoGebra工具系列_多边形(Polygon)
前端·javascript
知其然亦知其所以然38 分钟前
小米的奇幻编程之旅:当 JavaScript 语法变成了一座魔法城
前端·javascript·面试