С помощью следующего кода:IE и Chrome игнорируя JQuery вызов до Ajax поста
$('#langHref').html("Translating...").css("color","#FF9933");
jQuery.ajax({
type: "post"
, url: someUrl
, data: { "text": $('body').html() }
, async: false
, success: function (data, status) {
$('body').html(data);
},
error: function() {
alert('We are sorry, there was an error in the translation service.');
//console.log("ERROR", arguments);
}
});
$('#langHref').html("Select Language").css("color","");
}
У меня есть <a>
тег с идентификатором «langHref», идея в том, что как раз перед Аяксом называется текст ссылки установлен на «Перевод ...», а его цвет изменился на оранжевый. После завершения ajax текст ссылки возвращается к стандарту «Выбрать язык».
Это хорошо работает в FF, но не работает в IE и Chrome. Я пробовал все параметры beforeSend jQuery и события ajaxSend, чтобы попытаться установить его до выхода ajax, но безрезультатно.
Если я отключу async: false, то, очевидно, это немедленно изменит текст на «Выбрать язык», и вы не увидите, что он работает. Я также попробовал async: true и поместил вызов «Translating ....» beforeSend, который не работает в любом браузере, который я пробовал.
Мысли?
Хорошо сделанный asaabridge, я попробовал beforeSend, но я не пробовал полностью. Прекрасно работает! – Synergyauto