У меня есть DIV, в котором эти данные загружаются с сервера. Я хочу, чтобы мой JS выполнялся только тогда, когда в Div есть данные. Данные загружаются с помощью API Facebook,Хотите выполнить скрипт после загрузки данных в Div
<Div id='profilePicsDiv' > DATA</div>
JS
$(document).ready(function() {
FB.getLoginStatus(function (response) {
var profilePicsDiv = document.getElementById('profile_pics');
FB.api({
method: 'friends.get'
}, function (result) {
// var result =resultF.data;
// console.log(result);
var user_ids = "";
var totalFriends = result.length;
// console.log(totalFriends);
var numFriends = result ? Math.min(25, result.length) : 0;
// console.log(numFriends);
if (numFriends > 0) {
for (var i = 0; i < numFriends; i++) {
var randNo = Math.floor(Math.random() * (totalFriends + 1))
user_ids += (',' + result[randNo]);
randNo++;
if (randNo >= totalFriends) {
randNo = 0;
}
// console.log(user_ids);
}
}
profilePicsDiv.innerHTML = user_ids;
});
});
}
Теперь я хочу после того, как данные загружены, чтобы выполнить эту
$(document).ready(function() {
var user_ids = document.getElementById('profile_pics').innerHTML;
if (user_ids == '') {} else
{
FB.ui({
method: 'apprequests',
message: 'See anyones secret hidden pictures :)',
to: user_ids,
/// How to Fill the ID's HERE ?
}, requestCallback);
}
}
function requestCallback(response) {
// Handle callback here
}
});
Но 80% я получаю предупреждения, как пустой и 20% времени я получаю значения. Могу ли я сделать что-то, что эта функция будет выполнена после того, как она обязательно будет иметь данные и избежать 80% -ной вероятности ее Бланка?
вы имеете в виду, данные загружаются через AJAX после определенного интервала? И это происходит неоднократно? –
Данные загружаются API Facebook – Yahoo
Использование window.onload в сочетании с document.ready является избыточным. Избавьтесь от window.onload и придерживайтесь jQuery. Теперь, как вы получаете данные в этот div? Пожалуйста, опубликуйте этот код, чтобы мы получили полную картину. Удачи! :) – jmort253