У меня есть некоторые скрипты, которые меняют мое веб-приложение. Что в основном делает:jQuery append не видит изменений?
- Добавить динамические элементы в DOM
- Изменение размера некоторых DOM элементов, чтобы соответствовать высоте окна и другие вещи ...
Итак, я:
$(document).ready ->
$('.interval-view').wrapInner '<div class="column" />'
$('.column').wrapInner '<div class="inner-column" />'
$('#contents, #footers').append '<div class="clearfix"></div>'
$('.interval-view:even').css 'background-color', '#F9F9F9'
$('.interval-view:odd').css 'background-color', '#DDD'
resize = ->
$('.column').height $(window).height() - $('#filter-list').outerHeight(true) - $('#footers').outerHeight(true)
$('#timeline-panel').width $(window).width()
$('#timeline-panel .scrollable-area').width "#{$('.interval-view').length * $('.interval-view').width()}px"
window.onorientationchange = ->
resize()
$(window).resize ->
resize()
resize()
Но, я не получаю правильное значение высоты на $('.column').height
. Сценарий возвращает мне значение высоты, как если бы я не добавлял элемент clearfix
. Это похоже на то, что он не учитывает эту часть, когда вычисляет конечную высоту.
Я даже пробовал с отложенным объектом, но не успел. Он по-прежнему занимает высоту без учета элемента clearfix
.
Для не CoffeeScript людей, здесь я вставить сгенерированный Javascript:
$(document).ready(function() {
var resize;
$('.interval-view').wrapInner('<div class="column" />');
$('.column').wrapInner('<div class="inner-column" />');
$('#contents, #footers').append('<div class="clearfix"></div>');
$('.interval-view:even').css('background-color', '#F9F9F9');
$('.interval-view:odd').css('background-color', '#DDD');
resize = function() {
$('.column').height($(window).height() - $('#filter-list').outerHeight(true) - $('#footers').outerHeight(true));
$('#timeline-panel').width($(window).width());
return $('#timeline-panel .scrollable-area').width("" + ($('.interval-view').length * $('.interval-view').width()) + "px");
};
window.onorientationchange = function() {
return resize();
};
$(window).resize(function() {
return resize();
});
return resize();
});
Любой способ исправить это?
Но моя проблема не связана с событиями, это с нагрузкой страницы. После загрузки страницы события изменения размера отлично работают. Единственное, что не очень хорошо работает на странице загрузки (без запуска любого события изменения размера, конечно) – frarees