0

我正在尝试用已弃用的替换navigator.getUserMedianavigator.mediaDevices.getUserMedia但在尝试时出现此错误:

TypeError:无法设置未定义的属性“localStream”

这是我的 HTML:

   <video ref="videoPlayer" hide.bind="screenSharing" id="videoPlayer" autoplay muted></video>

我正在使用 Aurelia 环境,我的 javascript 是这样的:

attached() {

 if (!this.localStream) {
  this.getLocalMedia();
 }
}    

getLocalMedia() {
 let constraints: MediaStreamConstraints = {
   video: true,
   audio: true
 };

navigator.mediaDevices.getUserMedia(constraints)
  .then(function (stream) {
    console.log('Got mic+video stream', stream);
    this.localStream = stream;
    this.videoPlayer.srcObject = this.localStream;
    this.videoPlayer.srcObject = stream;
   })
   .catch (function (err) {
     console.error(err);
 });
// navigator.getUserMedia(constraints, (stream) => {
//   console.log('Got mic+video stream', stream);
//   this.localStream = stream;
//   this.videoPlayer.srcObject = this.localStream;
// },
//   (err) => {
//     console.error(err);
//   }
// );

  }

有人可以想象有什么问题吗?我正在使用 Electron 创建一个应用程序。

我在互联网上看到其他人有类似的问题,所以我打印了流:

Got mic+video stream 
MediaStream {id: "EIGkOQeyfsaRpweVgRG8eQiZfiuJ2HV3QZqW", active: true,     onaddtrack: null, onremovetrack: null, onactive: null…}
active: true
id: "EIGkOQeyfsaRpweVgRG8eQiZfiuJ2HV3QZqW"
onactive: null
onaddtrack: null
oninactive: null
onremovetrack: null
__proto__: MediaStream

当文档准备好时,我也尝试添加一个 EventListener,但我仍然遇到这个问题;如果我将注释部分与已弃用的 navigator.getUserMedia 一起使用,一切正常

4

1 回答 1

1

您在旧的 navigator.getUserMedia 中使用了箭头函数,但在 navigator.mediaDevices.getUserMedia 中使用了经典函数。正如安德烈亚斯所说this不是你想象的那样,这些风格之间的行为是不同的。

于 2019-02-05T10:43:02.553 回答