如何从Angular2服务访问FB全局?

Per*_*eoh 5 facebook-graph-api typescript angular-cli angular

我正在尝试使用通过新的angular CLI创建的Angular2项目中的FB SDK。我创建了以下服务来初始化Facebook库,添加了fbsdk类型并可以编译所有内容,但是除了“ winwow.fbAsyncInit”函数之外,我无法从项目中的任何位置访问FB全局变量。我可以从控制台完美地检查FB对象,但无法从NG2代码访问它。¿任何关于问题可能出在哪里的想法?

import { Injectable, OnInit } from '@angular/core'
import { FACEBOOK_APPID } from '../constants'

@Injectable()
export class fbService implements OnInit{
  constructor(){}
  ngOnInit(){
    if (!window.fbAsyncInit) {
        window.fbAsyncInit = function () {
            FB.init({
                appId: FACEBOOK_APPID,
                xfbml: false,
                version: 'v2.6'
            });
            FB.api("/me",null,()=>{})
            console.log(FB)
        };
    }
    this.initFB()           
}
initFB(){
  var js, id = 'facebook-jssdk', ref = document.getElementsByTagName('script')[0];
    if (document.getElementById(id)) {
        return;
    }
    js = document.createElement('script');
    js.id = id;
    js.async = true;
    js.src = "//connect.facebook.net/en_US/sdk.js";
    ref.parentNode.insertBefore(js, ref);
}
getPost(page:string){
     FB.api(`/${page}/feed?limit=1`,null,(response)=>{console.log(response)})
}
}
Run Code Online (Sandbox Code Playgroud)

Mar*_*oll 1

关键在于调用来this.zone.run(callback)包装回调并将其重新插入到 Angular 2 生命周期中。

我在服务构造函数中初始化 SDK,与立即加载相比,这可能会带来一些延迟。还没有找到解决方法。

我还没有决定是否为FB一旦初始化或包装方法提供访问器,我将把它留给您。

@Injectable()
export class FbsdkService {
    public ready = new BehaviorSubject<boolean>(false);

    constructor(
        private zone: NgZone) {
        this.loadSdkAsync(() => {
            FB.init({
                appId: "XXXXXXXXXXX",
                status: false,
                xfbml: false,
                version: "v2.7"
            });
            this.ready.next(true);
        });
    }

    loadSdkAsync(callback: () => void) {
        window.fbAsyncInit = () => this.zone.run(callback);
        // Load the Facebook SDK asynchronously
        const s = "script";
        const id = "facebook-jssdk";
        var js, fjs = document.getElementsByTagName(s)[0];
        if (document.getElementById(id)) return;
        js = document.createElement(s); js.id = id;
        js.src = "//connect.facebook.net/en_US/sdk.js";
        fjs.parentNode.insertBefore(js, fjs)
    }
}
Run Code Online (Sandbox Code Playgroud)