Текущий CSS: плавающий столбец с максимальной шириной и переполнением - PullRequest
8 голосов
/ 15 апреля 2010

Я использую изменчивый макет новой темы, над которой я работаю для своего блога. Я часто пишу о коде и включаю блоки <pre> в сообщения. Столбец float: left для области содержимого имеет значение max-width, поэтому столбец останавливается на определенной максимальной ширине и также может быть уменьшен:

+----------+     +------+
|   text   |     | text | 
|          |     |      |
|          |     |      |
|          |     |      |
|          |     |      |
|          |     |      |
+----------+     +------+
    max           shrunk

Я хочу, чтобы элементы <pre> были шире, чем текстовый столбец, чтобы я мог разместить 80-символьный код без горизонтальных полос прокрутки. Но я хочу, чтобы элементы <pre> были переполнены из области содержимого, не влияя на ее текучесть:

+----------+     +------+
| text     |     | text | 
|          |     |      |
+----------+--+  +------+------+
| code        |  | code        |
+----------+--+  +------+------+
|          |     |      |
+----------+     +------+
    max           shrunk

Но max-width перестает быть плавным, когда я вставляю туда нависающий <pre>: ширина столбца остается равной указанному max-width, даже когда я уменьшаю браузер выше этой ширины.

Я воспроизвел проблему с помощью этого сценария минимума:

<code><div style="float: left; max-width: 460px; border: 1px solid red">
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit</p>
<pre style="max-width: 700px; border: 1px solid blue">
function foo() {
    // Lorem ipsum dolor sit amet, consectetur adipisicing elit
}

Lorem ipsum dolor sit amet, специалист по адептизингу elit

Я заметил, что выполнение любого из следующих действий возвращает текучесть:

  1. Удалить <pre> (дох ...)
  2. Удалить float: left

Обходной путь, который я использую в настоящее время, заключается в вставке элементов <pre> в «разрывы» в столбце записей, чтобы ширины сегментов записей и сегментов <pre> управлялись исключительно взаимно:

+----------+     +------+
| text     |     | text | 
+----------+     +------+
+-------------+  +-------------+
| code        |  | code        |
+-------------+  +-------------+
+----------+     +------+
+----------+     +------+
    max           shrunk

Но это заставляет меня вставлять дополнительные закрывающие и открывающие элементы <div> в разметку поста, которые я предпочел бы сохранить семантически нетронутыми.

Правда, я не совсем понимаю, как блочная модель работает с плавающими объектами с переполненным содержимым, поэтому я не понимаю, почему комбинация float: left на контейнере и <pre> внутри него наносит вред max-width контейнера.

Я наблюдаю ту же проблему в Firefox / Chrome / Safari / Opera. IE6 (сумасшедший) кажется счастливым все время.

Это также не зависит от режима причуда / стандартов.

Обновление

Я провел дополнительное тестирование, чтобы заметить, что max-width, кажется, игнорируется, когда элемент имеет float: left. Я взглянул на главу о коробочной модели W3C, но не смог сразу увидеть явное упоминание этого поведения. Есть указатели?

Ответы [ 4 ]

4 голосов
/ 25 апреля 2010

Установите margin-right: -240px; float: left; на элементе <pre>, чтобы он занимал как можно меньше горизонтального пространства и в то же время может переполнить родительский элемент <div> на 240px. Не забудьте убедиться, что элементы <p> очищают плавающие элементы с обеих сторон (clear: both). Полный пример ниже:

<code><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" 
    "http://www.w3.org/TR/html4/strict.dtd">
<html>
    <head>
        <title>Solution</title>
    </head>
    <body>
        <div style="float: left; background-color: cyan; max-width: 460px;">
            <p style="background-color: magenta; clear: both;">
                Lorem ipsum dolor sit amet, consectetur adipisicing elit. 
                Lorem ipsum dolor sit amet, consectetur adipisicing elit. 
                Lorem ipsum dolor sit amet, consectetur adipisicing elit.
            </p>
            <pre style="float: left; max-width: 700px; 
                background-color: yellow; margin-right: -240px;">
function foo() {
    // Lorem ipsum dolor sit amet, consectetur adipisicing elit
}
            

Lorem Ipsum Dolor Sit Amet, Заклинатель, жировой элит. Lorem Ipsum Dolor Sit Amet, Заклинатель, жировой элит. Lorem Ipsum Dolor Sit Amet, Заклинатель, жировой элит.

1 голос
/ 25 апреля 2010

Я думаю, что это должно делать то, что вы ищете, но вам, возможно, придется слегка его настроить, чтобы заставить работать на месте.

<code><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
    <head>
        <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
        <title>Test</title>
        <style type="text/css" media="screen">
            body
            {
                margin: 0;
                padding: 0;
            }
            #wrapper
            {
                float: left;
                width: 100%;
            }
            #content
            {
                float: left;
                width: 100%;
                max-width: 500px;

                margin: 0;
                padding: 0;

                font-family: "Trebuchet MS", sans-serif;
                font-size: 12px;
            }
            #content-pad
            {
                margin: 50px;
                padding: 50px 0 40px 50px;
                background-color: #CCC;
            }

            p, pre
            {
                margin: 0 50px 10px 0;
                line-height: 1.6em;
            }

            pre
            {
                padding: 20px;
                width: 560px;

                background-color: #333;
                color: #FFF;
            }
        </style>
    </head>
    <body>
        <div id="wrapper">
            <div id="content">
                <div id="content-pad">
                    <p>Fusce euismod nunc vitae orci vestibulum adipiscing. Nam id quam libero, sed convallis elit. Etiam interdum, urna et imperdiet euismod, nisi erat commodo elit, sed convallis magna est quis sem. Fusce tempor aliquet est, et ornare eros vulputate et. Vivamus arcu augue, pretium vel fermentum in, gravida sed elit. Vestibulum ut ligula ac quam hendrerit ullamcorper. Phasellus id justo augue. Integer a eros ante. Vivamus sapien mi, placerat a viverra pharetra, dignissim sit amet ipsum. Fusce nunc nunc, tempus ut aliquet sit amet, consectetur sed quam. Cras ligula enim, bibendum eget luctus a, convallis sit amet nisl. Nullam in quam in lectus faucibus lobortis vel pulvinar ante.</p>
                    <pre>Here is some code!
We're going to make sure that it has a full eighty characters to play in.
12345678901234567890123456789012345678901234567890123456789012345678901234567890

Nullam in sapien vitae dui tincidunt elementum. Curabitur condimentum vulputate sem ornare pharetra. Fusce in dolor eget neque viverra sagittis a a orci. Vivamus Blandit Leo Eget Orci Viverra Quis Hendrerit Velit Tempus. Donec in erat risus. Nullam Scelerisque faucibus ante, ultricies tristique dolor laoreet sit amet. Duis сидят, а между тем ipsum. Sed sed Nibh Vel Ipsum Commodo Cursus. Proin fermentum nunc in Velit tincidunt imperdiet sit amet nec neque. Suspendisse neque ante, luctus sit amet pulvinar eu, congue laoreet magna. Энея сидят, аме портититор квам. Mauris hendrerit vulputate tempus. Curabitur mauris magna, laoreet congue rutrum condimentum, приправа в сапиене. Пеллетентный обитатель Morbi Tristique Senectus et netus и malesuada Fames ac turpis egestas.

<! - этот следующий элемент просто правильно поддерживает поле ->
0 голосов
/ 20 апреля 2010

Это может сработать

pre {
  position:relative;
  float:left;
  z-index: 1;
}

относительное положение делает предварительное "выпадение" из размеров столбца, не удаляя его из потока документов, и float должен регулировать ширину предварительного, чтобы он содержал все его содержимое.

0 голосов
/ 19 апреля 2010

CSS:

pre {
    display: inline-block;
}

Работает для Chrome и FireFox, что заставляет меня думать, что оно будет работать как минимум на Opera, Safari и IE8.

Если это нарушает IE6, вы можете использовать этот селектор, чтобы скрыть правило из браузера:

div > pre {
    display: inline-block;
}

В вашем примере (с добавлением дополнительных символов):

<code><div style="float: left; max-width: 460px; border: 1px solid red">
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit</p>
<pre style="max-width: 700px; border: 1px solid blue; display: inline-block;">
function foo() {
    // Lorem ipsum dolor sit amet, consectetur adipisicing elit dfsf sdf sdf sdf sdf
}

Lorem ipsum dolor sit amet, элитист-адептсайтинг, элит

...