我正在制作一个网络应用,需要使用权限查询来检查是否已授予用户相机访问权限。
我试过代码:
navigator.permissions.query({name:'camera'}).then(function(result) {
console.log(result);
});
它在 Google Chrome 70 上运行良好,但在 firefox 上出现错误:
TypeError:PermissionDescriptor“camera”的“name”成员不是枚举 PermissionName 的有效值。
我一直在寻找这个问题,但没有任何帮助。
有人能帮帮我吗?
谢谢,
最佳答案
Permissions API 被标记为一项实验性技术。
问题是 Firefox 确实有 navigator.permissions 并且也支持 query 方法,但是,它不支持列出的所有权限名称在 MDN's Permissions API page .
您可以自己尝试:转到 Firefox 的控制台并执行
// geolocation is working fine
navigator.permissions.query({ name: 'geolocation' }).then(console.log)
// camera, microphone is not supported, throws
navigator.permissions.query({ name: 'camera' })
// TypeError: 'name' member of PermissionDescriptor 'camera' is not a valid value for enumeration PermissionName.
navigator.permissions.query({ name: 'microphone' })
// TypeError: 'name' member of PermissionDescriptor 'microphone' is not a valid value for enumeration PermissionName.
在 mozilla/standards-positions 中有关于 Github 的公开讨论关于他们在 Permissions API 上的立场。老实说,据我所知,他们还没有得出任何结论。
您可以做的是创建一个基本功能,该功能可以在没有权限信息的情况下在所有浏览器上运行,而在 Chrome 上,您可以通过使用 Permissions.query 来确定权限来逐步增强用户体验用于相机和麦克风。
或者,您可以使用 MediaDevices.getUserMedia 提出一些逻辑来处理此问题:例如,您可以调用 getUserMedia 并立即停止轨道,如果您唯一想要的是确保您的应用程序具有授予麦克风和摄像头的权限。不过要小心,这有很多问题:
关于javascript - Firefox 权限 : 'name' member of PermissionDescriptor 'camera' is not a valid value for enumeration PermissionName,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53147944/