вертикально выровнять div внутри div с помощью jquery?
-
12-09-2019 - |
Вопрос
У кого-нибудь есть опыт работы с плагинами jquery vAligh или подобными?
Я попытался выровнять следующее, но это не удалось.Я использовал простой плагин valign (я помещу его в конце, это расширение jquery), если кто-нибудь может помочь, это будет очень полезно...
var overlayLayer = $("<div id='office-location'></div>").addClass('modal-overlay');
$('body').append(overlayLayer);
$('<div id="content-for-overlay" style="background-color: white;"></div>').appendTo(overlayLayer);
this.render({ to: "content-for-overlay", partial: "office-location-modal" }); // this just copies html into the layer
$('#content-for-overlay').vAlign(); THIS USES a plugin called valign but it doesn't align
$("body").css("overflow", "hidden");
$('#office-location').css("opacity", 0.8).fadeIn(150);
$('#content-for-overlay').css("opacity", 1);
вот расширение FN..
(function($) {
$.fn.vAlign = function() {
return this.each(function(i) {
var h = $(this).height();
var oh = $(this).outerHeight();
var mt = (h + (oh - h)) / 2;
$(this).css("margin-top", "-" + mt + "px");
$(this).css("top", "50%");
$(this).css("position", "absolute");
});
};
}) (jQuery);
Решение
Вы можете попробовать использовать технику CSS для вертикального центрирования элементов, как показано. здесь.Я считаю, что этот метод является кроссбраузерным, хотя, к сожалению, он добавляет в разметку дополнительный элемент div.
Было бы довольно легко применить этот CSS к разметке с помощью jQuery, используя $().css()
Не связан с StackOverflow