IE 8 показывает необработанный ajax-ответ при перезагрузке страницы с помощью jQuery BBQ
Я использую плагины jQuery BBQ и jQuery от Ben Almans для ссылок на страницы. Оба работают как положено в Opera и Firefox, но не в IE 8 (удивленно, а?). IE также хорошо работает с ajax, кнопкой возврата и hashchange, но завершается неудачно, когда я нажимаю кнопку перезагрузки, и показывает необработанный ответ ajax вместо запуска его на ранее загруженной странице.
Вот мой уродливый код и некоторые пояснения к функциям, которые я пытаюсь реализовать в своей пагинации:
1) Дружественные поисковикам ссылки (сервер отвечает html или js в зависимости от наличия javascript на стороне клиента).
2) Динамически изменяемый URL, когда JS включен (с помощью символа "#").
3) Поддержка истории и кнопки возврата.
4) Минимизация двойных запросов (не делайте ajax-запрос, если тот же контент был загружен с HTML-страницей).
JS:
$(function ($) {
if (ajax_init) {
$('.pagination a').live("click", function () {
$.bbq.pushState({page: $.deparam.querystring($(this).attr('href')).page});
return false;
});
$(window).bind("hashchange", function(e) {
var anchor = $.deparam.fragment().page;
var query = $.deparam.querystring().page;
if (ajax_load(anchor, query)) {
$(ajax_div).css('opacity', '0.4');
$(ajax_div + '-processing').removeClass('hidden');
$.ajax({
type: 'GET',
url: $.param.querystring('', {page: anchor}),
dataType: 'script',
cache: false
});
}
});
$(window).trigger('hashchange');
}
});
function ajax_load(anchor, query) {
if ((anchor && anchor !== query && !(!query && anchor == 1)) || $('#noscript').length < 1) {
return true;
}
else {
return false;
}
}
Шаблон (вид Rails):
<div id="products-container" >
<div id="products-processing" class="hidden">
<%= image_tag "spinner.gif" %>
</div>
<div id="products">
<div id="noscript">
<%= render "products_list.erb" %>
</div>
<script type="text/javascript">
var ajax_init = true;
var ajax_div = '#products';
var anchor = $.deparam.fragment().page;
var query = $.deparam.querystring().page;
if (!ajax_load(anchor, query)) {
url = anchor ? anchor : (query ? query : 1);
$.bbq.pushState({page: url});
}
else {
$('#noscript').hide();
$('#products-processing').removeClass('hidden');
}
</script>
</div>
<div id="products-min-height"></div>
</div>
Шаблон AJAX (представление Rails js):
$('#products').html('<%= escape_javascript(render "products_list") %>').css('opacity', '1');
UPD: IE не отправляет заголовок типа запроса (или Rails не может его определить) при обновлении. Поэтому Rails генерирует JS-представление вместо HTML. Решено:
respond_to do |format|
request.format.js? ? (format.js {render :index}) : (format.html {render :index})
end
Есть ли лучшее решение?
2 ответа
IE, кажется, запрашивает "*/*" при обновлении, а rails, похоже, считает, что javascript - лучший ответ, чем html. Поскольку обновление должно происходить только для html, сообщение rails о том, что "*/*" означает, что html устраняет эту проблему:
before_filter :set_request_type
...
protected
def set_request_type
request.format = :html if request.format == "*/*"
end
У меня была такая же проблема с IE8. Мой контроллер обслуживал JS, а также HTML-ответы. Для меня обеспечение того, чтобы блок формата html был отмечен первым в коде, решило проблему:
Это не работает, потому что rails отвечает шаблоном js:
respond_to do |format|
format.js
format.html
end
Это, однако, работает просто отлично:
respond_to do |format|
format.html
format.js
end