首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >navigator.mediaDevices仅在AngularJs Contraller中未定义

navigator.mediaDevices仅在AngularJs Contraller中未定义
EN

Stack Overflow用户
提问于 2020-04-26 20:16:53
回答 1查看 869关注 0票数 1

我正在尝试访问AngularJs控制器中的javasctipt mediaDevices --这是我的控制器代码:

代码语言:javascript
复制
(function () {
    'use strict';

    angular.module('app')
        .controller('AssistenzaCtrl', ['$scope', 'largeTabController', 'readSelect', '$mdDialog', '$interval', '$http', '$window', AssistenzaCtrl])

    function AssistenzaCtrl($scope, largeTabController, readSelect, $mdDialog, $interval, $http, $window ) {

        $scope.init = function () {
            if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {
              console.log("enumerateDevices() not supported.");
            } 
            navigator.mediaDevices.enumerateDevices()
            .then(function(devices) {
              devices.forEach(function(device) {
                console.log(device.kind + ": " + device.label +
                            " id = " + device.deviceId);
              });
            })
            .catch(function(err) {
              console.log(err.name + ": " + err.message);
            });             
        }   
    }
})();   

如果我用F12工具测试我的控制器,navigator.mediaDevices是未定义的,但我的浏览器支持mediaDevices,因为如果我在没有AngularJs的独立页面中运行相同的代码,我可以成功地枚举我的设备。

AngularJs和getUserMedia()之间是否存在兼容性问题?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-26 23:13:17

这个问题与使用http协议而不是od https有关。浏览器仅为https或本地主机连接启用getUserMedia。

我希望这个答案能对某人有所帮助。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61447502

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档