Css move div center

Содержание
  1. Align a div to center
  2. The usual technique for this is margin:auto
  3. Выравниваем блок по центру страницы
  4. Вариант 1. Отрицательный отступ.
  5. Вариант 2. Автоматический отступ.
  6. Вариант 3. Таблица.
  7. Вариант 4. Псевдо-элемент.
  8. Вариант 5. Flexbox.
  9. Вариант 6. Transform.
  10. Вариант 7. Кнопка.
  11. Бонус
  12. Как выровнять блок по центру — полное руководство по центрированию DIV-элемента
  13. Простое центрирование DIV-элемента на странице
  14. Центрируем DIV внутри DIV-элемента старым способом
  15. Центрируем DIV внутри DIV-элемента с помощью inline-block
  16. Центрируем DIV внутри DIV-элемента горизонтально и вертикально
  17. Центрируем DIV по нижней границе страницы
  18. Центрируем DIV на странице вертикально и горизонтально
  19. Делаем адаптивное центрирование DIV-элемента на странице
  20. Центрируем DIV внутри элемента с помощью свойств внутреннего блока
  21. Центрируем два адаптивных div-элемента рядом друг с другом
  22. DIV-элемент, центрированный при помощи Flexbox
  23. How to center a div with CSS?
  24. 7 Answers 7

Align a div to center

There is no float to center per se. If you want to center a block element inside another do this:

Now that won’t make the text wrap around it (like it would with a float left or right) but like I said: there is no float center.

For those frustrated after doing this and it still isn’t working, put ‘display:inline-block;’ in your «#outer» arguments

This has always worked for me.

Provided you set a fixed width for your DIV, and the proper DOCTYPE, try this

The usual technique for this is margin:auto

However, old IE doesn’t grok this so one usually adds text-align: center to an outer containing element. You wouldn’t think that would work but the same IE’s that ignore auto also incorrectly apply the text align center to block level inner elements so things work out.

And this doesn’t actually do a real float.

Note that ‘old IE’ means IE 5.x and earlier, which most people don’t concern themselves with these days.

Only in Quirks Mode (and you should not be using quirks mode except under truly exceptional circumstances)

floating divs to center «works» with the combination of display:inline-block and text-align:center.

Try changing width of the outer div by resizing the window of this jsfiddle

Following solution worked for me.

One of my websites involves a div whose size is variable and you won’t know it ahead of time. it is an outer div with 2 nested divs, the outer div is the same width as the first nested div, which is the content, and the second nested div right below the content is the caption, which must be centered. Because the width is not known, I use jQuery to adjust accordingly.

and then I center the captions in jQuery like this

captionWidth=$("#captions").css("width"); outerWidth=$("#outer-container").css("width"); marginIndent=(outerWidth-captionWidth)/2; $("#captions").css("margin","0px "+marginIndent+"px"); 

Источник

Выравниваем блок по центру страницы

Очень часто стоит задача выровнять блок по центру страницы / экрана, да ещё и так, чтобы без ява-скрипта, без задания жёстких размеров или отрицательных отступов, ещё чтобы и скроллбары работали у родителя, если блок превышает его размеры. В сети ходят достаточно много однообразных примеров как выровнять блок по центру экрана. Как правило большинство из них основаны на одних принципах.

Ниже представлены основные способы решения задачи, их плюсы и минусы. Чтобы понимать суть примеров, рекомендую уменьшить высоту / ширину окошка Result в примерах по указанным ссылкам.

Вариант 1. Отрицательный отступ.

Позиционируем блок атрибутами top и left на 50%, и заранее зная высоту и ширину блока, задаём отрицательный margin, который равен половине размера блока. Огромным минусом данного варианта является то, что нужно подсчитывать отрицательные отступы. Так же блок не совсем корректно ведёт себя в окружении скроллбаров — он попросту обрезается так как имеет отрицательные отступы.

Читайте также:  Bak omga su login index php

Вариант 2. Автоматический отступ.

Менее распространённый, но схожий с первым. Для блока задаём ширину и высоту, позиционируем атрибутами top right bottom left на 0, и задаём margin auto. Плюсом данного варианта являются рабочие скроллбары у родителя, если у последнего задана 100% ширина и высота. Минусом данного способ является жёсткое задание размеров.

Вариант 3. Таблица.

Задаём родителю табличные стили, ячейке родителя устанавливаем выравнивание текста по центру. А блоку задаём модель строчного блока. Минусами мы получаем не рабочие скроллбары, и в целом не эстетичность «эмуляции» таблицы.

Чтобы добавить скролл в данный пример, придётся добавить в конструкцию ещё один элемент.
Пример: jsfiddle.net/serdidg/xkb615mu.

Вариант 4. Псевдо-элемент.

Данный вариант лишён всех проблем, перечисленных у предыдущих способов, а так же решает первоначально поставленные задачи. Суть состоит в том, чтобы у родителя задать стили псевдо-элементу before, а именно 100% высоту, выравнивание по центру и модель строчного блока. Так же само и у блока ставится модель строчного блока, выравнивание по центру. Чтобы блок не «падал» под псевдо-элемент, когда размеры первого больше чем родителя, указываем родителю white-space: nowrap и font-size: 0, после чего у блока отменяем эти стили следующими — white-space: normal. В данном примере font-size: 0 нужен для того, чтобы убрать образовавшийся пробел между родителем и блоком в связи с форматированием кода. Пробел можно убрать и иными способами, но лучшим считается просто его не допускать.

либо, если вам нужно, чтобы родитель занимал только высоту и ширину окна, а не всей страницы:

Вариант 5. Flexbox.

Одним из самых простых и элегантных способов является использования flexbox. Но имейте ввиду, что центральное позиционирование сохраняется даже если родительский блок меньше дочернего, последний будет выходить за рамки и обрезаться.

В случае, если при уменьшении родительского блока дочерний не должен обрезаться по краям, используйте авто маржины:

Вариант 6. Transform.

Подходит в случае если мы ограничены структурой, и нет возможности манипулировать родительским элементом, а блок выровнять как-то нужно. На помощь придёт css функция translate() . При значение 50% абсолютное позиционирование расположит верхний левый угол блока точно по центру, затем отрицательное значение translate сдвинет блок относительно своих собственных размеров. Учтите, что могут всплыть негативные эффекты в виде размытых граней или начертания шрифта. Также подобный способ может привести к проблемах с вычислением положения блока с помощью java-script’а. Иногда для компенсации потери 50% ширины из-за использования css свойства left может помочь заданное у блока правило: margin-right: -50%; .

Вариант 7. Кнопка.

Пользователь azproduction предложил вариант, где блок обрамляется в тег button. Кнопка имеет свойство центрировать всё, что находится у неё внутри, а именно элементы строчной и блочно-строчной (inline-block) модели. На практике использовать не рекомендую.

Бонус

Используя идею 4-го варианта, можно задавать внешние отступы для блока, и при этом последний будет адекватно отображаться в окружении скроллбаров.
Пример: jsfiddle.net/serdidg/ugnp8ry7.

Так же можно выравнивать картинку по центру, и в случае если картинка больше родителя, масштабировать её по размеру родителя.
Пример: jsfiddle.net/serdidg/Lhpa1s70.
Пример с большой картинкой: jsfiddle.net/serdidg/tor2yudn.

Читайте также:  Programming arduino with java

Источник

Как выровнять блок по центру — полное руководство по центрированию DIV-элемента

Сегодняшняя статья направлена на то, чтобы показать, как при помощи нескольких CSS-трюков выровнять div по центру, как по горизонтали, так и по вертикали. Также мы расскажем, как произвести центрирование по всей странице либо в отдельно взятом div-элементе .

Простое центрирование DIV-элемента на странице

Этот метод будет отлично работать во всех браузерах.

Значение auto в свойстве margin устанавливает левый и правый отступ на все пространство, доступное на странице. Здесь важно запомнить, что у центрируемого div-элемента обязательно должно быть установлено значение width .

Центрируем DIV внутри DIV-элемента старым способом

Этот метод div выравнивания по центру будет работать во всех браузерах.

Внешний div может быть помещен как угодно, но у внутреннего блока div обязательно должна быть указана ширина ( width ).

Центрируем DIV внутри DIV-элемента с помощью inline-block

В этом методе центрирования div внутри div необязательно указывать ширину внутреннего элемента. Он будет работать во всех современных браузерах, включая IE8 .

Свойство text-align работает только в inline-элементах . Значение inline-block позволяет отобразить внутренний div в качестве inline-элемента , а также в качестве блока ( inline-block ). Свойство text-align во внешнем div-элементе позволит нам центрировать внутренний div .

Центрируем DIV внутри DIV-элемента горизонтально и вертикально

Здесь для центрирования div по центру страницы используется margin: auto . Пример будет работать во всех современных браузерах.

У внутреннего div-элемента должна быть указана ширина ( width ) и высота ( height ). Метод не сработает, если у внешнего div-элемента будет фиксированная высота.

Центрируем DIV по нижней границе страницы

Здесь для расположения div по центру по вертикали используется margin: auto и абсолютное позиционирование для внешнего элемента. Метод будет работать во всех современных браузерах.

У внутреннего div должна быть установлена ширина. Пространство внизу страницы регулируется с помощью свойства bottom внешнего div . Вы также можете центрировать div по верхней границе страницы, заменив свойство bottom на свойство top .

Центрируем DIV на странице вертикально и горизонтально

Здесь, чтобы выровнять div по центру, снова используется margin: auto и абсолютное позиционирование внешнего div . Метод будет работать во всех современных браузерах.

У div-элемента должна быть установлена ширина ( width ) и высота ( height ).

Делаем адаптивное центрирование DIV-элемента на странице

Здесь для выравнивания div по центру средствами CSS мы делаем ширину div-элемента адаптивной, чтобы она реагировала на изменения размеров окна. Этот метод работает во всех браузерах.

У центрированного div-элемента должно быть установлено свойство max-width .

Центрируем DIV внутри элемента с помощью свойств внутреннего блока

Внутренний div-элемент здесь адаптивен. Этот метод расположения div внутри div по центру будет работать во всех браузерах.

У внутреннего div должно быть установлено свойство max-width .

Центрируем два адаптивных div-элемента рядом друг с другом

Здесь у нас два расположенных рядом адаптивных div-элемента. Этот метод установки div по центру экрана будет работать во всех современных браузерах.

.container < text-align: center; >.left-div < display: inline-block; max-width: 300px; vertical-align: top; >.right-div < display: inline-block; max-width: 150px; >screen and (max-width: 600px) < .left-div, .right-div < lef max-width: 100%; >>

Здесь у нас несколько элементов с примененным свойством inline-block , расположенных внутри центрированного контейнера. В этом примере также используются медиа-запросы CSS ; то есть, если размер экрана меньше 600 пикселей, то свойство max-width как для левого, так и для правого div-элемента устанавливается на 100%.

Читайте также:  Таблица регулярных выражений python

DIV-элемент, центрированный при помощи Flexbox

Здесь мы располагаем CSS div по центру с помощью Flexbox . Он предназначен для того, чтобы облегчить процесс разработки дизайна пользовательских интерфейсов. Этот модуль поддерживается Chrome 38+ , IE11 , Microsoft Edge , Firefox 38+ , Safari 9+ , Opera 30+ , iOS Safari 9+ , а также Android Browser 40+ .

Значение свойства height может быть любым, но только больше размера центрированного div-элемента.

Валентин Сейидов автор-переводчик статьи « THE COMPLETE GUIDE TO CENTERING A DIV »

Источник

How to center a div with CSS?

I am learning HTML/CSS, and so far, I still have difficulties with CSS, especially when it comes to positioning. For instance, can anyone explain to me why the following doesn’t work?

7 Answers 7

Now define your #main ID display:inline-block and give to text-align:center in your .centerer class

Write to do this as like this

Yes, but what I want is 50*30 blue block centered in my page and that the centering comes from a parent.

@Colas If all these working examples stop working after you try them in your code, don’t you think that your code is probably messing it up.

For that to work you need to give .center a definite width, or else the browser can’t compute the margins for left and right. The following should work:

You can get your desired resulth through margin:auto;

Try giving the centerer div a width.

.centerer is centred, it has width: auto (the default) so is as wide as its container, and it looks the same as if it was left- or right-aligned.

If you want to centre #main then you have to set auto margins on #main itself.

Yes, I know, but my point is that I want to center .centerer and that the content appears in it ! (I need to fix different margins for #main, actually). I cant understand why it doesn’t work !! Isnt .centerer supposed to be centered in body ? See my other question stackoverflow.com/questions/13230107/…

@Colas — Paragraph one of my answer addresses centring centerer. Paragraph two addresses centring the content of centerer.

why is .centered not centered relatively to ? Why dont the centering property propagate to children ?

@Colas — .centred is centred relative to the body. You just can’t see it because it is the same width as the body. If you centre a block, then its block-level children are not automatically centred inside it because it is comparatively rare that people want that sort of layout.

No, it doesn’t (hence why the background colour extends to the width of the container and not just the width of the text).

You want #main to be in center, so you have to give margin:0 auto; to #main.

Using margin:0 auto will centre the DIV fine, but you have to supply a width in order for it to work properly.

Here is your HTML/CSS code updated so that the DIVs will be centrally aligned.

Alternatively, you could get rid of the .centerer div, instead just making the #main div centered itself, by applying the same CSS — you’ve already got a width defined so just add margin:0 auto; . However, if you want other items centered within the .centerer container, keep things as they are.

Источник

Оцените статью