javascript - 如何从 3rd 方库访问 Angular 组件

标签 javascript angular typescript deezer

我正在构建通过官方 JS SDK 使用 Deezer 播放器的网络应用程序。我遇到的问题是我无法从 Deezer 事件订阅访问我的 Angular 组件。箭头函数不理解 this 的上下文,因此我无法调用组件的方法并将值传递给它们。实现该目标的正确方法是什么?

app.component.ts

// ...

declare var DZ;

// ...

export class AppComponent implements OnInit {
    currentTrack: any = null;

    constructor() {}

    ngOnInit(): void {
        DZ.init({
            appId  : '8',
            channelUrl : 'https://developers.deezer.com/examples/channel.php',
            player : {
                onload : this.onPlayerLoaded
            }
        });
    }

    onPlayerLoaded() {
        DZ.player.playAlbum(302127);

        DZ.Event.subscribe('player_position', console.log);
        DZ.Event.subscribe('current_track', (response) => {
            // I would like to pass response.track to setCurrentTrack() there
        });
    }

    setCurrentTrack(track) {
        this.currentTrack = track;
    }
}

index.html

// ...

<head>
    <script type="text/javascript" src="https://e-cdns-files.dzcdn.net/js/min/dz.js"></script>
</head>

// ...

最佳答案

为了帮助其他人,您应该 .bind(this) 到您的函数调用,因为 this 可能指的是 DZ 上下文,而不是您的类:

ngOnInit(): void {
    DZ.init({
        appId  : '8',
        channelUrl : 'https://developers.deezer.com/examples/channel.php',
        player : {
            onload : this.onPlayerLoaded.bind(this)  //Fix right here
        }
    });
}

关于javascript - 如何从 3rd 方库访问 Angular 组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55957890/

相关文章:

javascript - 正则表达式查找最后一个空格字符

javascript - javascript中获取超链接后的textarea内容

javascript - 如何显示隐藏类(class)?

Angular 2隐藏或显示子组件

angular - 我收到错误 TS2345 : Argument of type 'number' is not assignable to parameter of type 'string'

javascript - Angular Material 拖放 : Custom Pipe Issue

Javascript抽象成员

Angular 2 RC2 新形式

javascript - Ionic 2 中的本地存储无法访问 then() 方法之外的数据

javascript - 如何修复 Angular 中未定义的形式错误 'validate'