如果我运行它,我会收到“正在发送”的消息,但不会显示“已收到”的消息。为什么?错误消息是失败和错误块中的无传输。
html:
<ul>
<li><a href="http://www.hotmail.com">hotmail.com</a></li>
<li><a href="http://www.google.com">google.com</a></li>
</ul>
js:
<script type="text/javascript">
$(document).ready(function () {
$("a").each(function (index) {
var sUrl = 'http://tinyurl.com/api-create.php?url=' + $(this).attr('href')
alert('sending: ' + sUrl);
$.ajax({
url: sUrl,
crossDomain: true
}).fail(function (data) {
alert('failed: ' + data.statusText);
}).error(function (data) {
alert('error: ' + data.statusText);
}).done(function (data) {
alert('received: ' + sUrl);
});
});
});
</script>
编辑:接受的答案使用 $.getJSON 在内部调用 $.ajax。对于那些可能对低级 $.ajax 感兴趣的人,请看这里。
$('a').each(function (index) {
var app = 'http://json-tinyurl.appspot.com/';
var sUrl = app + '?url=' + $(this).attr('href') + '&callback=?';
$.ajax({
url: sUrl,
dataType: 'json',
success: function (data) {
alert('ajax:' + data.tinyurl);
},
error: function (jqXHR, textStatus, errorThrown) {
alert("jqXHR=" + jqXHR.responseText + "\ntextStatus=" + textStatus + "\nerrorThrown=" + errorThrown);
}
});
});