Мой вызов AJAX ничего не возвращает, но и не дает сбоя.
-
21-09-2019 - |
Вопрос
У меня есть этот HTML:
<input type="text" id="text"/>
<input type="button" id="submit" value="Submit" />
<div id="twitter_update_list">
</div>
и этот JavaScript:
var xmlHttp;
document.body.onclick = function(){
var username = document.getElementById('text').value;
selectUser(username);
}
function selectUser(username){
var url = "http://twitter.com/statuses/user_timeline/" + username + ".json?callback=twitterCallback2&count=100";
try{// Opera 8.0+, Firefox, Safari
xmlHttp = new XMLHttpRequest();
}catch (e){// IE
try{
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try{
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e){
// Something went wrong
alert("Your browser broke!");
return false;
}
}
}
xmlHttp.onreadystatechange = processRequest;
xmlHttp.open( "GET", url, true );
xmlHttp.send( null );
}
function processRequest(){
if ((xmlHttp.readyState == 4) && (xmlHttp.status == 200)) {
if ( xmlHttp.responseText == "Not found" ) {
document.getElementById('twitter_update_list').innerHtml = "Not found";
}else if(xmlHttp.responseText == " "){
document.getElementById('twitter_update_list').value = "Empty";
}else{
// No parsing necessary with JSON!
document.getElementById('twitter_update_list').value = xmlHttp.responseText;
console.log(xmlHttp.responseText);
}
}
}
Я смотрю на Firebug и вижу, что все отправляется правильно, но я не получаю никакого ответа.Да, и я использую чистый JavaScript, потому что хочу попрактиковаться в нем."="
Решение
Вы пытаетесь выполнить междоменный XMLHttpRequest.Это не работает, хотя служба может поддерживать JSONP.Чтобы выполнить запрос JSOP, вам нужно либо ввести <script>
тег с правильными обработчиками событий или используйте такую структуру, как jQuery.
Другие советы
Если вы используете jquery, вы можете просто сделать это
$.load("http://twitter.com/statuses/user_timeline/"+username,
function(data)
{
alert(data);
}
);
который будет печатать пользовательскую шкалу для данного имени пользователя
Не связан с StackOverflow