首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带Facebook SDK的HotTowel SPA

带Facebook SDK的HotTowel SPA
EN

Stack Overflow用户
提问于 2013-04-28 04:46:53
回答 2查看 787关注 0票数 3

我已经使用HotTowel SPA模板启动了一个新的Visual Studio2012Express Web项目。我不确定我应该把加载HotTowel结构中的Facebook SDK的代码放在哪里?

我试过main.js和shell.js,但我似乎无法加载sdk。Facebook说放入下面的代码来异步加载sdk

代码语言:javascript
复制
window.fbAsyncInit = function () {
    // init the FB JS SDK
    FB.init({
        appId: '577148235642429',                        // App ID from the app dashboard
        channelUrl: '//http://localhost:58585/channel.html', // Channel file for x-domain comms
        status: true,                                 // Check Facebook Login status
        xfbml: true                                  // Look for social plugins on the page
    });

    // Additional initialization code such as adding Event Listeners goes here
};

// Load the SDK asynchronously
(function (d, s, id) {
    var js, fjs = d.getElementsByTagName(s)[0];
    if (d.getElementById(id)) { return; }
    js = d.createElement(s); js.id = id;
    js.src = "//connect.facebook.net/en_US/all/debug.js";
    fjs.parentNode.insertBefore(js, fjs);

}(document, 'script', 'facebook-jssdk'));
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-04-28 13:35:49

在名为facebooksdk.js的文件中创建一个模块,该文件包含以下代码。然后“要求”引导序列中的代码,如果您希望它立即加载。

票数 1
EN

Stack Overflow用户

发布于 2013-05-28 22:01:37

在Durandal中使用Facebook SDK并不容易。

Facebook向instructions提供了如何使用require来设置它。但听起来这种方法并不是supported in Durandal

我通过使用支持knockout的vm包装全局FB对象来创建我的脏版本。您可以很容易地使用它并绑定到任何属性,如用户名。

包括来自shell.js facebook.js,以确保在应用程序启动时加载它。

这是我的facebook.js:

代码语言:javascript
复制
define(['services/logger'], function (logger) {
var vm = {
    facebook: null,
    initialized: ko.observable(false),
    name: ko.observable(""),
    picturesrc: ko.observable(""),
    login: login,
    logout: logout
};

$.ajaxSetup({ cache: true });
$.getScript('//connect.facebook.net/en_UK/all.js', function () {
    window.fbAsyncInit = function () {
        vm.facebook = FB;
        vm.facebook.init({
            appId: '160000000000499',
            status: true,
            cookie: true,
            xfbml: true,
            oauth: true
        });
        vm.initialized(true);
        vm.facebook.getLoginStatus(updateLoginStatus);
        vm.facebook.Event.subscribe('auth.statusChange', updateLoginStatus);
    };
});    
return vm;

function login() {
    vm.facebook.login( function(response) {
        //Handled in auth.statusChange
    } , { scope: 'email' });
}

function logout() {
    vm.facebook.logout( function (response) {
        vm.picturesrc("");
        vm.name("");
    });
}

function updateLoginStatus(response) {
    if (response.authResponse) {
        logger.log("Authenticated to Facebook succesfully");
        vm.facebook.api('/me', function (response2) {
            vm.picturesrc('src="https://graph.facebook.com/' +
                +response2.id + '/picture"');
            vm.name(response2.name);

        });
    } else {
        logger.log("Not authenticated to Facebook");
        vm.picturesrc("");
        vm.name("");
    }
}

});

我没有正确地测试我的代码。但至少在Chrome中登录和获取名称工作得很好。

请记住,在developers.facebook.com上更改appId并更新正确的域。

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

https://stackoverflow.com/questions/16256718

复制
相关文章

相似问题

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