これを実行すると、「送信中」のメッセージは表示されますが、「受信済み」のメッセージは表示されません。なぜ?失敗およびエラー ブロックのエラー メッセージは No Transport です。
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>
編集: 受け入れられた回答は、内部で $.ajax を呼び出す $.getJSON を使用します。低レベルの $.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);
}
});
});