Я борюсь с разочаровывающей и глубоко базовой проблемой CSS, которая проиллюстрирована на диаграмме ниже, и js fiddle here. Я пытаюсь достичь макета жидкой сетки с плавающими блочными элементами, определенными процентной шириной и различной высотой, которые линеаризуют - то есть изменяются на width: 100%
на определенной точке останова (в скрипте есть медиа-запрос @ 768px max-width.) Обратите внимание, что мне нужны блоки для линеаризации таким образом, чтобы «переплетать» две основные колонии вместе, как показано на скрипке. У меня возникла проблема с тем, что плавающие элементы «отбрасываются» и не выравниваются по вертикали по желанию - как указано блоком «news/speaking» на моей диаграмме.Drop float - основной вопрос о размещении CSS
Я пробовал все Кладку тип JQuery плагин я могу найти, и ни один из них не кажется, выполняет в последовательном или надежном способе, с жидкостными раскладками. Я также знаю метод inline-block
, но причуды/ограничения создают свои проблемы. Кроме того, flexbox выглядит фантастически, но текущая ограниченная поддержка является проблемой для этого проекта в частности.
Я открыт для подхода, основанного на jquery, то есть заставляя определенные блоки выравниваться по дну других, но предпочитает использовать css-based. Я понимаю, что всегда могу применить отрицательный запас к элементам «dropping», но это не очень изящное решение.
Любая помощь с этой проблемой «поплавок» наиболее ценится.
Изменение '' .item.w1' от поплавка: left' на 'дисплей: встроенный блок;' кажется, для решения проблема, но вы упомянули «причуды/ограничения» с этим подходом? https://jsfiddle.net/7Lc7ofm6/ –
@RickHitchcock, возможно, он имел в виду применение inline-блока как к .w1, так и к .w2. Но да, я не вижу проблем с вашим решением. – zgood
@zgood - да, я был проиндеденен, ссылаясь на использование встроенного блока для всех элементов, но еще не пробовал его только для левых элементов с плавающей точкой (т. Е. 'Item.w1'). спасибо, я сделаю снимок на моем сайте. – nickpish