CSS: центральный блок, но выровнять содержимое слева

Я хочу, чтобы весь блок был центрирован в его родителе,но я хочу, чтобы содержимое блока было выровнено.

примеры служат лучше всего

на странице :

http://yaml-online-parser.appspot.com/?yaml=%23+ASCII+Art%0d%0a---+%7c%0d%0a++%5c%2f%2f%7c%7c%5c%2f%7c%7c%0d%0a++%2f%2f+%7c%7c++%7c%7c__%0d%0a&type=python

искусство ascii должно быть центрировано (как кажется), но оно должно выстраиваться и выглядеть так "В YAML".

или такой :

http://yaml-online-parser.appspot.com/?yaml=%3f+-+Detroit+Tigers%0d%0a++-+Chicago+cubs%0d%0a%3a%0d%0a++-+2001-07-23%0d%0a%0d%0a%3f+%5b+New+York+Yankees%2c%0d%0a++++Atlanta+Braves+%5d%0d%0a%3a+%5b+2001-07-02%2c+2001-08-12%2c%0d%0a++++2001-08-14+%5d%0d%0a

сообщение об ошибке должно выстраиваться в линию, как в консоли.

8 ответов


сначала создайте родителя div это центрирует его дочернее содержимое с text-align: center. Затем создайте ребенка div использует display: inline-block приспособиться к ширине своих детей и text-align: left чтобы содержимое, которое он держит, выровнялось слева по желанию.

<div style="text-align: center;">
    <div style="display: inline-block; text-align: left;">
        Centered<br />
        Content<br />
        That<br />
        Is<br />
        Left<br />
        Aligned
    </div>
</div>

перепечатка рабочего ответа из другого вопроса:как горизонтально центрировать плавающий элемент переменной ширины?

предполагая, что элемент, который плавает и будет центрирован, является div с id="content" ...

<body>
<div id="wrap">
   <div id="content">
   This will be centered
   </div>
</div>
</body>

и примените следующий CSS

#wrap {
    float: left;
    position: relative;
    left: 50%;
}

#content {
    float: left;
    position: relative;
    left: -50%;
}

вот хорошая ссылка на это http://dev.opera.com/articles/view/35-floats-and-clearing/#centeringfloats


Если я вас хорошо понимаю, вам нужно использовать для центра контейнера (или блока)

margin-left: auto;
margin-right: auto;

и влево выровнять его содержимое:

text-align: left;

<div>
    <div style="text-align: left; width: 400px; border: 1px solid black; margin: 0 auto;">
         <pre>
Hello
Testing
Beep
         </pre>
    </div>
</div>

обычно вы должны использовать margin: 0 auto на div, как указано в других ответах, но вам нужно будет указать ширину div. Если вы не хотите указывать ширину, которую вы можете использовать (это зависит от того, что вы пытаетесь сделать), используйте поля, что-то вроде margin: 0 200px;, это должно заставить ваш контент казаться, что он центрирован, вы также можете увидеть ответ Leyu на У меня вопрос


это то, что вы ищете? Модель Flexbox...

.container{
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-content: center;
  align-items: center;
}
.inside{
  height:100px;
  width:100px;
  background:gray;
  border:1px solid;
}
<section class="container">
  <section class="inside">
    A
  </section>
  <section class="inside">
    B
  </section>
  <section class="inside">
    C
  </section>
</section>

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

HTML-код:

<div>
  <p>Some interesting text.</p>
</div>

CSS:

P {
  width: 50%; //or whatever looks best
  margin: auto; //top and bottom margin can be added for aesthetic effect
}

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


это работает

<div style="display:inline-block;margin:10px auto;">
    <ul style="list-style-type:none;">
        <li style="text-align:left;"><span class="red">❶</span> YouTube AutoComplete Keyword Scraper software <em>root keyword text box</em>.</li>
        <li style="text-align:left;"><span class="red">❷</span> YouTube.com website <em>video search text box</em>.</li>
        <li style="text-align:left;"><span class="red">❸</span> YouTube AutoComplete Keyword Scraper software <em>scraped keywords listbox</em>.</li>
        <li style="text-align:left;"><span class="red">❹</span> YouTube AutoComplete Keyword Scraper software <em>right click context menu</em>.</li>
    </ul>
</div>