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>
相关推荐
pan_junbiao5 分钟前
Vue循环遍历:v-for 指令
前端·javascript·vue.js
<有心人>33 分钟前
vue使用axios请求后端数据
java·前端·javascript·vue.js
风清云淡_A35 分钟前
原生js中的深浅拷贝笔记
前端·javascript
怎么吃不饱捏2 小时前
表格滚动分页查询
前端·javascript·vue.js
软件技术NINI2 小时前
JavaScript 对象属性
javascript·网络·udp
疯狂学习GIS2 小时前
ArcGIS创建渔网工具的使用方法
arcgis·gis·学术工作效率
余子桃2 小时前
Elementui-Plus动态渲染图标icon
前端·javascript·elementui
TTong___2 小时前
【Electron】桌面应用开发electron-builder打包报错问题处理
前端·javascript·electron
前端怎么个事3 小时前
vue 跳转页面-$router.resolve和$router.push区别
前端·javascript·vue.js
怠惰小白程序员3 小时前
自动续期 双token流程
前端·javascript