how to properly inject Facebook JavaScript SDK to AngularJS controllers?

后端 未结 5 1806
一整个雨季
一整个雨季 2021-02-02 14:01

I\'m new to AnuglarJS and already built a small web-app with it, I would like to use the Facebook JavaScript SDK with it, but using best practices (dependency injecting to contr

5条回答
  •  被撕碎了的回忆
    2021-02-02 14:38

    I have actually had to do this... I don't have the code with me, and it's probably proprietary anyhow... but it was essentially like this:

    // create a simple factory:    
    app.factory('facebook', ['$window', function($window) {
    
        //get FB from the global (window) variable.
        var FB = $window.FB;
    
        // gripe if it's not there.
        if(!FB) throw new Error('Facebook not loaded');
    
        //make sure FB is initialized.
        FB.init({
           appId : 'YOUR_APP_ID'
        });
    
        return {
            // a me function
            me: function(callback) {
                FB.api('/me', callback);
            }
    
            //TODO: Add any other functions you need here, login() for example.
        }
    }]);
    
    // then you can use it like so:
    app.controller('SomeCtrl', function($scope, facebook) {
    
        //something to call on a click.
        $scope.testMe = function() {
    
           //call our service function.
           facebook.me(function(data) {
              $scope.facebookUser = data;
    
              //probably need to $apply() this when it returns.
              // since it's async.
              $scope.$apply();
           });
        };
    });
    

    If there are any errors in that let me know, and I'll look up the working code I have and see what I've missed. But that should be about it.

提交回复
热议问题