Facebook画布:Uncaught TypeError:无法调用未定义的方法'sort'
问题描述:
我有一个奇怪的问题。我多的朋友选择的JavaScript代码运行在我的本地正常,但当我打开它在我的Facebook应用程序的画布里面,它在all.js的81线当我与铬调试引发错误Facebook画布:Uncaught TypeError:无法调用未定义的方法'sort'
Uncaught TypeError: Cannot call method 'sort' of undefined
开发人员工具localhost上,我可以看到响应对象调用排序方法,但在Facebook应用程序中,响应对象是错误对象。我的JavaScript有什么不对吗?或在Facebook上加载iframe时执行的任何特定任务?
我已加载以下顺序库:
<script src="/static/interface/js/jquery.min.js"></script>
<script src="http://connect.facebook.net/en_US/all.js"></script>
<script src="/static/interface/js/bootstrap.min.js"></script>
<script src="/static/interface/js/jquery.facebook.multifriend.select.js"></script>
<link rel="stylesheet" href="/static/interface/css/jquery.facebook.multifriend.select.css"/>
这里是javascript代码
<script>
FB.init({appId: '460948667348013', cookie: true});
FB.getLoginStatus(function(response) {
if (response.session) {
init();
} else {
// no user session available, someone you dont know
}
});
function init() {
FB.api('/me', function(response) {
$("#username").html("<img src='https://graph.facebook.com/" + response.id + "/picture'/><div>" + response.name + "</div>");
$("#jfmfs-container").jfmfs({
max_selected: 15,
max_selected_message: "{0} of {1} selected",
friend_fields: "id,name,last_name",
pre_selected_friends: [1014025367],
exclude_friends: [1211122344, 610526078],
sorter: function(a, b) {
var x = a.last_name.toLowerCase();
var y = b.last_name.toLowerCase();
return ((x < y) ? -1 : ((x > y) ? 1 : 0));
}
});
$("#jfmfs-container").bind("jfmfs.friendload.finished", function() {
window.console && console.log("finished loading!");
});
$("#jfmfs-container").bind("jfmfs.selection.changed", function(e, data) {
window.console && console.log("changed", data);
});
$("#logged-out-status").hide();
$("#show-friends").show();
});
}
$("#show-friends").live("click", function() {
var friendSelector = $("#jfmfs-container").data('jfmfs');
$("#selected-friends").html(friendSelector.getSelectedIds().join(', '));
});
function sendRequest() {
var friendSelector = $("#jfmfs-container").data('jfmfs');
var sendUIDs = friendSelector.getSelectedIds().join(', ');
// Use FB.ui to send the Request(s)
FB.ui({method: 'apprequests',
to: sendUIDs,
title: 'My Great Invite',
message: 'Check out this Awesome App!',
}, callback);
}
function callback(response) {
// alert('callback called');
var friendSelector = $("#jfmfs-container").data('jfmfs');
var sendUIDs = friendSelector.getSelectedIds().join(',');
var uids = sendUIDs.split(',');
var query = '';
for(i=0;i<uids.length;i++){
if(i==0){
query = query + 'to[' + i + ']=' + uids[i];
}
else{
query = query + '&to[' + i + ']=' + uids[i];
}
}
console.log(query);
if(response){
// alert('successful');
window.location.assign("/?"+ query)
}
else{
alert('failure');
}
}
window.onload = function() {
init();
};
</script>
答
如果你插入的代码是all.js,它在我看来,它应该出现在标签列表的末尾,所以你已经加载了FB api。
此外,由于使用的是jQuery的,为什么要用
window.onload
时,你可以使用
$(document).ready(function() {
init();
});
?
或者,您确定所有其他脚本都可以在您导入时访问吗? (我假设他们是,但它不伤害检查。)