Содержание
Как CSS устанавливает выравнивание текста заполнителя?
Атрибут placeholder в HTML указывает короткую подсказку для описания ожидаемого значения поля ввода или текстового поля, то есть текста-заполнителя. Краткое приглашение отображается в поле до того, как пользователь вводит значение. В большинстве браузеров текст-заполнитель обычно выравнивается по левому краю. Итак, как установить метод выравнивания текста заполнителя? Следующая статья расскажет об этом, я надеюсь, что она будет полезна всем.
Как CSS устанавливает выравнивание текста заполнителя?
Вы можете использовать свойство text-align, чтобы установить выравнивание текста заполнителя с помощью селектора заполнителя CSS.
грамматика:
Этот селектор заполнителя CSS имеет разные способы записи в разных браузерах, например:
Для браузеров Chrome, Mozilla и Opera:
::placeholder
Для Internet Explorer:
:-ms-input-placeholder
Пример:Установите выравнивание текста заполнителя
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title> Выравнивание заполнителя </title>
<style>
input[type="email"]::placeholder {
/* Firefox, Chrome, Opera */
text-align: center;
}
input[type="text"]::placeholder {
/* Firefox, Chrome, Opera */
text-align: right;
}
input[type="tel"]::placeholder {
/* Firefox, Chrome, Opera */
text-align: left;
}
input[type="email"]:-ms-input-placeholder {
/* Internet Explorer 10-11 */
text-align: center;
}
input[type="email"]::-ms-input-placeholder {
/* Microsoft Edge */
text-align: center;
}
body {
text-align:center;
}
h2 {
color:green;
}
</style>
</head>
<body>
<h4> Выравнивание текста заполнителя </h4>
<p> Выравнивание по центру <br> <input type = "email" placeholder = "Email"> </p> <br>
<p> Выравнивание по правому краю <br> <input type = "text" placeholder = "Name"> </p> <br>
<p> Выравнивание по левому краю <br> <input type = "tel" placeholder = "Phone Number"> </p>
</body>
</html>
Изображение эффекта:
Рекомендуемая литература:
базовое руководство по java
Layui Framework
перейти к языку
Как выровнять текст по середине в css
Задача верстки, которая очень часто встречается – это выравнивание текста по вертикали в блоке div.
Если с выравниванием текста по горизонтали, проблем обычно не возникает (используем свойство text-align:center и все будет хорошо), то с выравниванием по вертикали все немного сложнее.
Есть одной свойство в CSS, которое называется vertical-align. Казалось бы, используя его можно решить все проблемы. Но не тут-то было.
Нужно учитывать такой момент, что vertical-align можно применять только для выравнивания содержимого ячеек таблиц или для строчных элементов, для выравнивания их друг относительно друга в пределах одной строки.
Для блочных элементов свойство vertical-align не работает.
Есть два способа, как можно выйти из этой ситуации:
Для тех, кто предпочитает все смотреть в видео:
Для тех, кто любит текст, читайте ниже способ решения этой проблемы.
Способ А. Как одно из решений, можно разместить текст не в элементе div, а в ячейке таблицы.
Способ Б. Использовать своство display:table-cell;
Все было бы хорошо, но старые браузеры не поддерживают display:table-cell, особенно IE с версии 7 и ниже.
Можно, конечно, наплевать на эти старые браузеры и выравнивать текст так. Доля браузера IE7 на моем сайте, по статистике за 1 квартал 2013 года, следующая:
Это меньше чем пол процента от всех посещений. В будущем этот процент будет еще более снижаться.
Есть некоторые хитрости, которые позволяют обойти эту проблему в IE7, но это значительное усложнение кода.
Кроме того, есть ситуации, в которых можно обойтись вообще без использования display:table-cell.
Ситуация 1. Выравнивание одной строки текста.
Рассмотрим простой пример.
Строка текста располагается по верхнему краю. Т.к. у нас всего одна строка текста, то для выравнивания можно воспользоваться самым простым способом: это добавление свойства line-height со значением равным высоте элемента div, в котором текст находится.
Этот способ хорошо работает, когда у вас всего одна строка с текстом.
Ситуация 2. Если известны точные значения ширины и высоты дочернего блока, где располагается сам текст.
Этот вариант решения предусматривает использование свойства position:absolute для дочернего блока, абсолютного его позиционирования относительно родительского блока с position:relative.
Зная ширину и высоту блока, можно взять половину этой величины и задать ее отрицательными значениями для свойств margin-left и margin-top.
Как видите, такая простая задача, как выравнивание текста по центру, оказалась не такой простой на практике.
Выравнивание текста — такая необходимость возникает очень часто. В CSS это реализуется с помощью соответствующих атрибутов и их значений. Что это за атрибуты, какие у них существуют значения и, наконец, как делается выравнивание текста в CSS с их помощью мы и рассмотрим в этом уроке.
Горизонтальное выравнивание в CSS
Для того, чтобы выровнять текст по горизонтали в CSS используется атрибут «text-align» со следующими значениями:
- text-align: left;
- text-align: right;
- text-align: center;
- text-align: justify;
- left — выравнивание текста по левому краю;
- right — горизонтальное выравнивание текста по правому краю;
- center — расположение текста по центру;
- justify — выравнивание по левому и правому краю одновременно (по ширине).
Вертикальное выравнивание в CSS
Для того, чтобы выровнять текст по вертикали в CSS используется атрибут «vertical-align» со следующими значениями:
- vertical-align: top;
- vertical-align: middle;
- vertical-align: bottom;
- top — выравнивание текста по верхнему краю;
- middle — вертикальное выравнивание текста по центру;
- bottom — выравнивание текста по нижнему краю.
Вот, пожалуй, и все. Выравнивание текста в CSS не должно вызвать каких-либо затруднений. Как видите, ничего сложного здесь нет. Спасибо за внимание и до встречи в других уроках!
Доброго времени суток, подписчики и читатели данной публикации. Сегодня я хочу вдаться в подробности и рассказать вам, как в css выровнять текст по центру. В некоторых предыдущих статьях я косвенно затрагивал данную тему, поэтому кое-какие знания в этой области у вас имеются.
Однако в данной публикации я расскажу вам о всевозможных способах выравнивания объектов, а также объясню, как делать отступы и красные строки в абзацах. Так что давайте приступать к изучению материала!
Html и его детища и align
Данный способ почти не используется, так как его вытеснили инструменты каскадных стилевых таблиц. Однако знание, что такой тег существует, вам не помешает.
Что касается валидации (данный термин подробно описан в статье «Как проверить html код на ошибки»), то в самой спецификации html осуждается использование , так как для валидности необходимо использовать переходной .
Такой тип пропускает запрещенные элементы.
jquery — Как выровнять текст под изображением в CSS?
Добавьте контейнер div для изображения и подпись:
<div>
<img src=""/>
<span>Text below the image</span>
</div>
Затем, с небольшим количеством CSS, вы можете создать автоматически упаковывающуюся галерею изображений:
div.item {
vertical-align: top;
display: inline-block;
text-align: center;
width: 120px;
}
img {
width: 100px;
height: 100px;
background-color: grey;
}
.caption {
display: block;
}
div.item {
/* To correctly align image, regardless of content height: */
vertical-align: top;
display: inline-block;
/* To horizontally center images and caption */
text-align: center;
/* The width of the container also implies margin around the images. */
width: 120px;
}
img {
width: 100px;
height: 100px;
background-color: grey;
}
.caption {
/* Make the caption a block so it occupies its own line. */
display: block;
}
<div>
<img src=""/>
<span>Text below the image</span>
</div>
<div>
<img src=""/>
<span>Text below the image</span>
</div>
<div>
<img src=""/>
<span>An even longer text below the image which should take up multiple lines.</span>
</div>
<div>
<img src=""/>
<span>Text below the image</span>
</div>
<div>
<img src=""/>
<span>Text below the image</span>
</div>
<div>
<img src=""/>
<span>An even longer text below the image which should take up multiple lines.</span>
</div>
http://jsfiddle.net/ZhLk4/1/
Обновленный ответ
Вместо того, чтобы использовать «анонимный» div и span, вы также можете использовать элементы HTML5 figure
и figcaption
. Преимущество заключается в том, что эти теги добавляют семантическую структуру документа. Визуально нет никакой разницы, но это может (положительно) повлиять на удобство использования и индексацию ваших страниц.
Тэги разные, но структура кода точно такая же, как вы можете видеть в этом обновленном фрагменте и скрипте:
<figure>
<img src=""/>
<figcaption>Text below the image</figcaption>
</figure>
figure.item {
/* To correctly align image, regardless of content height: */
vertical-align: top;
display: inline-block;
/* To horizontally center images and caption */
text-align: center;
/* The width of the container also implies margin around the images. */
width: 120px;
}
img {
width: 100px;
height: 100px;
background-color: grey;
}
.caption {
/* Make the caption a block so it occupies its own line. */
display: block;
}
<figure>
<img src=""/>
<figcaption>Text below the image</figcaption>
</figure>
<figure>
<img src=""/>
<figcaption>Text below the image</figcaption>
</figure>
<figure>
<img src=""/>
<figcaption>An even longer text below the image which should take up multiple lines.</figcaption>
</figure>
<figure>
<img src=""/>
<figcaption>Text below the image</figcaption>
</figure>
<figure>
<img src=""/>
<figcaption>Text below the image</figcaption>
</figure>
<figure>
<img src=""/>
<figcaption>An even longer text below the image which should take up multiple lines.</figcaption>
</figure>
http://jsfiddle.net/ZhLk4/379/
html — выровнять текстовое поле и текст /метки в HTML?
Мне нравится устанавливать ‘line-height’ в css для div, чтобы они правильно выстраивались в линию. Вот пример того, как я делаю это, используя asp и css:
ASP:
<div>
<div>
<asp:Label runat="server" Text="Date Created:"></asp:Label><br />
<asp:Label runat="server" Text="Last Login Date:"></asp:Label><br />
<asp:Label runat="server" Text="User ID:"></asp:Label><br />
<asp:Label runat="server" Text="Username:"></asp:Label><br />
<asp:Label runat="server" Text="First Name:"></asp:Label><br />
<asp:Label runat="server" Text="Last Name:"></asp:Label><br />
</div>
<div>
<asp:Label runat="server" Text="00/00/00 00:00:00"></asp:Label><br />
<asp:Label runat="server" Text="00/00/00 00:00:00"></asp:Label><br />
<asp:Label runat="server" Text="UserId"></asp:Label><br />
<asp:TextBox runat="server"></asp:TextBox><br />
<asp:TextBox runat="server"></asp:TextBox><br />
<asp:TextBox runat="server"></asp:TextBox><br />
</div>
</div>
А вот код в файле CSS, чтобы все вышеперечисленные поля выглядели красиво и аккуратно:
#profileRow1{width:100%;line-height:40px;}
#profileRow1Col1{float:left; width:25%; margin-right:20px;}
#profileRow1Col2{float:left; width:25%;}
.righty{text-align:right;}
вы можете извлечь все, кроме тегов DIV, и заменить его собственным содержимым.
Поверьте мне, когда я говорю, что он выглядит выровненным, как это делает изображение в оригинальном сообщении!
Я бы опубликовал скриншот, но Stack не позволил мне:
К сожалению! Ваше изменение не может быть отправлено, потому что:
Приносим извинения, но в качестве механизма предотвращения спама новым пользователям запрещено публиковать изображения. Заработайте более 10 репутации, чтобы публиковать изображения.
🙂
ответил Taylor Brown 2 AM000000120000005431 2012, 00:46:54
Как выровнять текст по центру блока css
Задача верстки, которая очень часто встречается – это выравнивание текста по вертикали в блоке div.
Если с выравниванием текста по горизонтали, проблем обычно не возникает (используем свойство text-align:center и все будет хорошо), то с выравниванием по вертикали все немного сложнее.
Есть одной свойство в CSS, которое называется vertical-align. Казалось бы, используя его можно решить все проблемы. Но не тут-то было.
Нужно учитывать такой момент, что vertical-align можно применять только для выравнивания содержимого ячеек таблиц или для строчных элементов, для выравнивания их друг относительно друга в пределах одной строки.
Для блочных элементов свойство vertical-align не работает.
Есть два способа, как можно выйти из этой ситуации:
Для тех, кто предпочитает все смотреть в видео:
Для тех, кто любит текст, читайте ниже способ решения этой проблемы.
Способ А. Как одно из решений, можно разместить текст не в элементе div, а в ячейке таблицы.
Способ Б. Использовать своство display:table-cell;
Все было бы хорошо, но старые браузеры не поддерживают display:table-cell, особенно IE с версии 7 и ниже.
Можно, конечно, наплевать на эти старые браузеры и выравнивать текст так. Доля браузера IE7 на моем сайте, по статистике за 1 квартал 2013 года, следующая:
Это меньше чем пол процента от всех посещений. В будущем этот процент будет еще более снижаться.
Есть некоторые хитрости, которые позволяют обойти эту проблему в IE7, но это значительное усложнение кода.
Кроме того, есть ситуации, в которых можно обойтись вообще без использования display:table-cell.
Ситуация 1. Выравнивание одной строки текста.
Рассмотрим простой пример.
Строка текста располагается по верхнему краю. Т.к. у нас всего одна строка текста, то для выравнивания можно воспользоваться самым простым способом: это добавление свойства line-height со значением равным высоте элемента div, в котором текст находится.
Этот способ хорошо работает, когда у вас всего одна строка с текстом.
Ситуация 2. Если известны точные значения ширины и высоты дочернего блока, где располагается сам текст.
Этот вариант решения предусматривает использование свойства position:absolute для дочернего блока, абсолютного его позиционирования относительно родительского блока с position:relative.
Зная ширину и высоту блока, можно взять половину этой величины и задать ее отрицательными значениями для свойств margin-left и margin-top.
Как видите, такая простая задача, как выравнивание текста по центру, оказалась не такой простой на практике.
Смотрите также указатель всех приёмов работы.
Центрирование
В последних реализациях CSS вы можете также использовать возможности Уровня 3 (CSS3), позволяющие выровнять по центру абсолютно позиционированные элементы:
- Выравнивание по вертикали в уровне 3
- Выравнивание по вертикали и горизонтали в уровне 3
- Выравнивание в области просмотра в уровне 3
Центрирование строк текста
Самый распространённый и (потому) самый лёгкий тип центрирования — это центрирование строк текста в абзаце или заголовке. Для этого CSS обладает свойством ‘text-align’:
которое отображает каждую строку в абзаце P или заголовке h3 по центру между полями, вот так:
Все строки в этом абзаце выровнены по центру полями абзаца. Это стало возможным благодаря значению ‘center’ свойства CSS ‘text-align’.
Центрирование блока или изображения
Иногда центрировать нужно не текст, а блок в целом. Или, по-другому говоря: мы хотим, чтобы правое и левое поля были одинаковыми. Для этого нужно установить поля на ‘auto’. Это обычно используется для блоков с фиксированной шириной, потому что если блок сам по себе гибкий, он просто займёт всю доступную ширину. Вот пример:
Этот довольно узкий блок текста центрирован. Заметьте, что строки внутри блока не центрированы (они выровнены влево), в отличие от предыдущего примера.
Этот метод также можно использовать для центрирования изображения: поместите его в собственный блок и примените свойства полей. Например:
Следующее изображение центрировано:
Вертикальное центрирование
Пример, приведенный ниже, демонстрирует центрирование абзаца внутри блока, который имеет определенную заданную высоту. Отдельный пример показывает абзац, который центрирован вертикально в окне браузера, потому что находится внутри блока, позиционированного абсолютно и по высоте окна.
Этот маленький абзац центрирован вертикально.
Центрирование по вертикали в CSS уровня 3
Уровень 3 CSS предлагает и другие возможности. На момент написания этой статьи (2014 год), хороший способ вертикального выравнивания блока без использования абсолютного позиционирования (что может приводить к частичному перекрытию текста) всё ещё обсуждается. Но если вам известно, что частичное перекрытие текста не станет проблемой в вашем документе, вы можете использовать свойство ‘transform’, чтобы выровнять по центру абсолютно позиционированный элемент. Например:
Этот абзац выровнен вертикально по центру.
Для документа, который выглядит вот так:
таблица стилей выглядит так:
Основные правила:
- Сделайте контейнер относительно позиционированным (position: relative), что превратит его в контейнер для абсолютно позиционированных элементов.
- Сам элемент сделайте абсолютно позиционированным (position: absolute).
- Поместите элемент посередине контейнера с помощью ‘top: 50%’. (Заметьте, что ‘50%’ здесь означают 50% высоты контейнера.)
- Используйте translate, чтобы переместить элемент вверх на половину своей собственной высоты. ( ‘50%’ в ‘translate(0, -50%)’ указывают на высоту самого элемента.)
Недавно (начиная приблизительно с 2015-го года) в нескольких реализациях CSS стала доступна новая техника. Она основана на новом ключевом слове ‘flex’ для свойства ‘display’. Это ключевое слово предназначено для использования в графическом интерфейсе пользователя (GUI), но ничто не мешает вам использовать его в документе, если у этого документа правильная структура.
Этот абзац выровнен по центру вертикально.
таблица стилей выглядит следующим образом:
Вертикальное и горизонтальное центрирование в CSS уровня 3
Мы можем расширить оба метода, чтобы центрировать по горизонтали и по вертикали одновременно.
Побочный эффект абсолютного позиционирования абзаца состоит в том, что абзац становится ровно таким широким, каким он должен быть (если только мы явно не укажем ширину). В примере ниже мы именно этого и хотим: мы размещаем по центру абзац из одного слова (“Центр!“), так что ширина абзаца должна быть равна ширине этого слова.
Жёлтый фон наглядно демонстрирует, что абзац действительно той же ширины, что и его содержимое. Мы подразумеваем, что разметка осталась прежней:
В плане вертикального центрирования эта таблица стилей схожа с таблицей из предыдущего примера. Но теперь мы ещё перемещаем элемент на полпути через контейнер с помощью правила ‘left: 50%’ и одновременно сдвигаем его влево на половину своей собственной ширины в преобразовании ‘translate’:
Следующий пример объясняет, зачем требуется правило ‘margin-right: -50%’.
Когда форматер CSS поддерживает ‘flex’, всё становится ещё легче:
с этой таблицей стилей:
т.е. единственным дополнением является ‘justify-content: center’. Точно также, как ‘align-items’ определяет вертикальное выравнивание содержимого контейнера, ‘justify-content’ таким же образом определяет горизонтальное выравнивание. (На самом деле всё несколько сложнее, как следует из их названий, но в простом случае, работает это именно так.). Побочный эффект от применения свойства ‘flex’ состоит в том, что дочерний элемент, в нашем случае это Р, автоматически становится настолько малым, насколько это возможно.
Центрирование в области просмотра в CSS уровня 3
Контейнером по умолчанию для абсолютно позиционированных элементов является область просмотра. (В случае c браузером это окно браузера). Таким образом, центрирование элемента в области просмотра не вызывает сложности. Далее приведен полный пример. (В этом примере использован синтаксис HTML5.)
Вы можете увидеть результат в отдельном документе.
Правило ‘margin-right: -50%’ необходимо для компенсации ‘left: 50%’. Правило ‘left’ уменьшает доступную для элемента ширину на 50%. Поэтому визуализатор постарается сделать линии длиною не более половины ширины контейнера. Указав на то, что правое поле элемента находится правее на ту же самую величину, отметим, что максимальная длина линии снова равняется ширине контейнера.
Попробуйте изменить размер окна: вы увидите, что каждое предложение находится на одной строке, когда окно достаточно широкое. Только тогда, когда окно слишком узкое для всего предложения, это предложение будет разбито на несколько строк. Когда вы удалите правило ‘margin-right: -50%’ и снова измените размер окна, вы заметите, что предложения будут уже разбиты, хотя окно все еще шире строк текста в два раза.
(Использование свойства ‘translate’ для центрирования в области просмотра было впервые предложено “Charlie” в ответе на сайте Stack Overflow.)
Навигация по сайту
Created 5 May 2001;
Last updated Вт 05 ноя 2019 19:12:56
Дата публикации: 2016-02-24
От автора: вновь приветствую вас на страницах нашего блога. В сегодняшней статье я бы хотел рассказать о различных приемах выравнивания, которое можно применять как к блокам, так и к их содержимому. В частности, как выровнять блоки в css, а также о выравнивании текста.
Выравнивание блоков по центру
В css выровнять блок по центру легко. Это самый известный многим прием, но о нем я хотел бы рассказать именно сейчас, в первую очередь. Здесь подразумевается выравнивание по центру по горизонтали относительно родительского элемента. Как оно осуществляется? Допустим, у нас есть контейнер и в нем наш подопытный:
Предположим, что это шапка сайта. Она не тянется на всю ширину окна и нам надо ее отцентрировать. Пишем так:
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Нам нужно указать точную или максимальную ширину, после чего записать ключевое свойство – margin: 0 auto. Оно задает внешние отступы нашей шапке, первое значение определяет отступы сверху и снизу, а второе – справа и слева. Значение auto дает команду браузеру автоматически рассчитать отступы с обеих сторон так, чтобы элемент был ровно по центру родительского. Удобно!
Выравнивание текста
Это тоже очень простой прием. Для выравнивания всех строчных элементов можно использовать свойство text-align и его значения: left, right, center. Последнее центрирует текст, что нам и нужно. Таким же образом можно выровнять даже картинку, потому что она тоже по умолчанию является строчным элементом.
Выравнивание текста по вертикали
А вот это уже посложнее. По умолчанию нет такого простого общеизвестного свойства, которое бы легко центрировало текст в блочной контейнере по вертикали. Однако есть несколько приемов, которые за годы работы придумали верстальщики.
Задать высоту блока с помощью внутренних отступов. Способ заключается в том, чтобы не задавать явную высоту с помощью height, а создать ее искусственно с помощью paddingов сверху и снизу, которые должны быть одинаковы. Создадим любой блок и запишем ему такие свойства:
Фон просто для того, чтобы визуально видеть края, а также внутренние отступы. Теперь высоту блока составляют два этих отступа и сама строка, а выглядит все это так:
Определить для блока line-height. Мне кажется, это более правильный способ, если вам надо выровнять одну строчку текста. При нем вы можете записать высоту по нормальному, с помощью свойсва height. После этого ему же нужно задать высоту строки, такую же, как и высота блока в целом.
Результат будет аналогичен вышеприведенной картинке. Все будет работать, даже если вы добавите внутренние отступы. Однако, только для одной строки. Если вам нужно больше текста в элементе, то данный способ работать не будет.
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Преобразовать блок в ячейку таблицы. Суть этого метода в том, что для ячейки таблицы действует свойство vertical-align: middle, которое центрирует элемент по вертикали. Соответственно, в этом случае блоку нужно задать следующее:
Этот способ хорош тем, что вы сможете выровнять сколько угодно текста по центру. Но блоку, в который вложен наш div лучше прописать display: table, иначе может не работать.
Ну вот мы и подошли к последнему на сегодня приему – это выравнивание самих блоков по вертикали. Нужно сказать, что тут опять же нет свойства, которое предназначалось бы специально для этого, но есть несколько приемов, о которых вы должны знать.
Задать отступы в процентах. Если вы знаете высоту родительского элемента и помещаете в него еще один блочный элемент, то отцентрировать его можно с помощью процентных отступов. Например, родитель имеет высоту 600 пикселей. Вы помещаете в него блок, который имеет высоту 300 пикселей. Сколько вам нужно отступить сверху и снизу, чтобы отцентрировать его? По 150 пикселей, а это 25% от высоты родителя.
Этот способ позволяет сделать центровку только когда размеры позволяют сделать вычисления. А если у вас родитель 887 пикселей в высоту, то точно записать ничего не получится, это и так понятно.
Вставить элемент в ячейку таблицы. Опять же, если мы преобразуем родительский элемент в ячейку таблицы, то вставленный в него блок автоматом отцентрируется по вертикали. Для этого родителю всего лишь нужно задать vertical-align: middle.
А если вдобавок к этому записать еще и margin: 0 auto, то элемент и по горизонтали станет в центр!
Использовать абсолютное позиционирование. Об этом способе мало кто знает. Нужно вставить в css такой код:
CSS свойство выравнивания текста по ширине
Пример
Установите метод выравнивания «между словами», если для параметра выравнивания текста установлено значение
«оправдать»:
div
{
выравнивание текста: выравнивание;
выравнивание текста по ширине: между словами;
}
Попробуй сам »
Определение и использование
Свойство выравнивания текста по ширине
определяет метод выравнивания
текста, если для параметра text-align установлено значение «выравнивание по ширине».
Значение по умолчанию: | авто |
---|---|
Унаследовано: | да |
Анимируемое: | нет.Прочитать о animatable |
Версия: | CSS3 |
Синтаксис JavaScript: | объект .style.textJustify = «inter-word» |
Поддержка браузера
Числа в таблице указывают первую версию браузера, полностью поддерживающую свойство.
Объект | |||||
---|---|---|---|---|---|
с выравниванием текста | Да * | 11.0 | 55,0 | 10.0.3 | Да * |
* Эта функция находится за параметром Включить экспериментальные функции веб-платформы (необходимо установить значение
Включено). Чтобы изменить настройки в Chrome: введите «chrome: // flags» в
Браузер Chrome. Чтобы изменить настройки в Opera: введите «флаги» в Opera.
браузер.
Синтаксис CSS
выравнивание текста: автоматически | между словами | между символами | нет | начальная | наследование;
Стоимость недвижимости
Значение | Описание | Играй |
---|---|---|
авто | Браузер определяет алгоритм согласования | Играй » |
межслово | Увеличивает / уменьшает расстояние между словами | Играй » |
межсимвольный | Увеличивает / уменьшает расстояние между символами | Играй » |
нет | Отключает методы обоснования | Играй » |
начальный | Устанавливает для этого свойства значение по умолчанию.Читать про начальные | Играй » |
унаследовать | Наследует это свойство от своего родительского элемента. Читать про наследство |
text-align-last — CSS: каскадные таблицы стилей
Свойство CSS text-align-last
устанавливает способ выравнивания последней строки блока или строки непосредственно перед принудительным разрывом строки.
выравнивание текста последний: авто;
выравнивание текста последний: начало;
выравнивание текста последний: конец;
выравнивание текста последний: слева;
выравнивание текста последний: право;
выравнивание текста последний: центр;
выравнивание текста последний: выравнивание;
выравнивание текста последний: наследование;
выравнивание текста последний: начальный;
выравнивание текста последний: вернуться;
выравнивание текста последний: отключено;
Значения
-
авто
Затронутая строка выравнивается по значению
text-align
, еслиtext-align
не равноjustify
, и в этом случае эффект такой же, как при установкеtext-align-last
наstart
.-
начало
То же, что и
слева,
, если направление слева направо, исправа,
, если направление справа налево.-
конец
То же, что и
справа,
, если направление слева направо, ислева,
, если направление справа налево.-
слева
Встроенное содержимое выравнивается по левому краю строчного поля.
-
правый
Встроенное содержимое выравнивается по правому краю строчного поля.
-
центр
Встроенное содержимое центрируется в рамке строки.
-
по ширине
Текст выровнен по ширине. Текст должен выровнять свои левый и правый края с левым и правым краями абзаца.
авто | начало | конец | слева | право | центр | justify
Обоснование последней строки
Целочисленный элемент массы при нулевом размещении varius.Suspendisse in libero risus, in interdum massa. Vestibulum ac leo vitae metus faucibus gravida ac in neque. Nullam est eros, suscipit sed dictum quis, accumsan a ligula.
CSS
p {
размер шрифта: 1.4em;
выравнивание текста: выравнивание;
выравнивание текста последний: центр;
}
Результаты
Таблицы BCD загружаются только в браузере
Выравнивание текста CSS
Свойство text-align
используется для горизонтального выравнивания элементов.В основном, он используется для выравнивания элементов встроенного уровня внутри элементов уровня блока. Таким образом, это свойство влияет на элементы inline и inline-block внутри элементов уровня блока.
Это свойство влияет на содержимое элемента, к которому оно применяется, а не на элемент.
CSS
Значения
слева
: выравнивает содержимое по левому краю линейного поля.
справа
: выравнивает содержимое по правому краю линейного поля.
по центру
: горизонтально центрирует содержимое внутри строкового блока.
выровнять по ширине
: Браузер регулирует интервал в тексте так, чтобы он начинался от левого края элемента и заканчивался у правого края, за исключением последней строки текста.
начало
: указывает, что содержимое выровнено по начальному краю линейного блока. Проще говоря, это то же самое, что слева,
, если направление слева направо, и справа,
, если направление справа налево.
конец
: указывает, что содержимое выровнено по конечному краю строкового блока. Проще говоря, это то же самое, что справа,
, если направление слева направо, и слева,
, если направление справа налево.
match-parent
: аналогично наследованию
, но унаследованные значения start
и end
указаны в соответствии с направлением родительского объекта
.
начало и конец
: задает начало
выравнивание первой строки или любой строки после принудительного разрыва строки и конец
выравнивание остальных строк.
начальный
: устанавливает значение свойства по умолчанию.
наследовать
: наследует значение от родительского элемента.
Новые значения в спецификации CSS3
Четыре новых значения start
, end
, match-parent
и start end
включены в спецификацию CSS3. Однако эти значения не следует использовать, потому что они не включены в окончательную рекомендацию.
Примеры
HTML
Этот текст выровнен по левому краю
Этот текст выровнен по центру
Этот текст выровнен по правому краю
CSS
p { цвет фона: # A7C9A7; } # para1 { выравнивание текста: слева; } # para2 { выравнивание текста: центр; } # para3 { выравнивание текста: вправо; }
См. Примеры выравнивания текста Pen от Aakhya Singh (@aakhya) на CodePen.
В приведенной выше демонстрации каждому абзацу присвоен цвет фона. Поскольку p является элементом уровня блока, он покрывает все доступное ему горизонтальное пространство. При присвоении разных значений text-align
трем абзацам их содержимое выравнивалось по левому, центру и правому краю относительно их контейнера соответственно.
В другом примере, приведенном ниже, все встроенные элементы внутри блока div , имеющего класс «parent», центрированы. Содержимое всех дочерних элементов уровня блока этого блока div также центрируется.
HTML
Это первый абзац внутри div, которому присвоено значение text-align: center. Поскольку 'p' является элементом уровня блока и дочерним элементом этого div, его содержимое также было центрировано.
Этот div является вторым потомком родительского div. Поскольку «div» также является элементом уровня блока, его содержимое также было центрировано. Ширина этого дочернего div установлена на 400 пикселей.Этот абзац является третьим дочерним элементом родительского div.Ему задается text-align: right, которое перекрывает значение, данное родительскому div, и выравнивает его содержимое по правому краю.
CSS
.parent { выравнивание текста: центр; размер шрифта: 17 пикселей; семейство шрифтов: «Noto Sans», без засечек; } .child1 { цвет фона: # A7C9A7; } .child2 { ширина: 400 пикселей; цвет фона: # C9A7A7; } .child3 { выравнивание текста: вправо; цвет фона: # A7C9C9; }
См. Пример пера с выравниванием текста от Аахьи Сингха (@aakhya) на CodePen.
Поддержка браузера
Это свойство поддерживается в Chrome, Firefox, Safari, IE3 +, iOS, Opera и Android.
CSS — выравнивание текста: центр; не точно по центру (Пример)
rossace23
3,819 Очки
Я работаю над навигационным разделом своей страницы и пытаюсь центрировать его точно посередине страницы. Я только начал кодировать раздел навигации и использую «text-align: center;» метод центрирования навигатора посередине страницы под моим изображением.Однако при использовании этого центрирование кажется немного неправильным, немного правее страницы. Я почти уверен, что это не оптическая иллюзия, поэтому может ли кто-нибудь взглянуть на мой код ниже и увидеть, что мне не хватает? Я использую firefox в качестве браузера.
При необходимости я могу вставить свой html-код, но на данном этапе он довольно простой, ничем не отличающийся от вступления к рабочему пространству html Treehouse.
/ ******************************************* ОБЩЕЕ ******************************************** / header { цвет фона: # 000; максимальная ширина: 25%; } a { текстовое оформление: нет; стиль границы: нет; наброски: нет; } ссылка { цвет белый; } а: посетил { цвет: # FFFFE9; } / ******************************************** ЗАГОЛОВОК ******************************************** / / * Для Padding: 0 = сверху, 0 = справа, 30px = снизу, 0 = слева (как при движении по часовой стрелке) * / .BandName { семейство шрифтов: 'Montserrat', без засечек; выравнивание текста: слева; маржа слева: авто; маржа-право: авто; отступ: 20 пикселей 20 пикселей 20 пикселей 20 пикселей; } / ******************************************** ТЕЛО ******************************************** / .middlepage { цвет фона: # 000; } .MouthsLogo { дисплей: блок; маржа слева: авто; маржа-право: авто; нижнее поле: 200 пикселей; margin-top: 0; высота: авто; ширина: авто; максимальная ширина: 150 пикселей; максимальная высота: 150 пикселей; отступ: 20 пикселей 20 пикселей 20 пикселей 20 пикселей; } / ******************************************** NAV ******************************************** / nav { выравнивание текста: центр; } / ******************************************** ФУТЕР ******************************************** / нижний колонтитул { цвет фона: #FFF; }
Введение в свойство CSS text-align-last
Иногда крошечные детали, которые в основном остаются незамеченными, могут повлиять на восприятие пользователем.Это может включать в себя тонкие тени текста, применяемые к заголовку, или правильный интервал между различными элементами на веб-странице.
Свойство text-align-last
полезно в этом отношении. Он определяет, как будет выровнена последняя строка блока или строка непосредственно перед принудительным разрывом строки. Это важно, потому что в последней строке абзаца обычно не хватает текста, чтобы заполнить все пространство. Вы можете заметить или не заметить изменения, но это улучшит общий вид вашего сайта.
В этом руководстве будут рассмотрены все аспекты свойства text-align-last
, включая допустимые значения, поддержку и поведение конкретного браузера.
Использование и возможные значения
Использовать text-align-last
в ваших проектах довольно просто. Вот базовый фрагмент для выравнивания последней строки текста по правому краю:
.intro-graph {
выравнивание текста: выравнивание; // Требуется для IE и Edge
выравнивание текста последний: право;
}
Это свойство имеет семь возможных значений.Вы, вероятно, знакомы с обычными значениями слева
, справа
и по центру
. Они выравнивают текст в последней строке слева, справа и по центру контейнера.
Следующая демонстрация показывает различия между этими тремя значениями:
См. Pen text-align-last — Example 1 от SitePoint (@SitePoint) на CodePen.
Четвертое значение, выравнивание по ширине
, выравнивает последнюю строку таким образом, что текст выравнивает ее левый и правый края по левому и правому краям контейнера.Это достигается за счет вставки соответствующего промежутка между словами, когда это необходимо. В зависимости от объема текста вы можете использовать это свойство, чтобы полностью заполнить пространство в последней строке без слишком большого промежутка между словами. Текст во втором абзаце также выравнивается по ширине, но, поскольку последняя строка содержит только одно слово, он выравнивается по левому краю.
См. Pen text-align-last — Example 2 от SitePoint (@SitePoint) на CodePen.
В то время как выравнивание по левому краю последней строки текста работает для языков, которые читаются слева направо (LTR), это будет неправильно делать с языками RTL.В таких случаях присвоение значений слева
или справа
может вызвать проблемы, если вы заранее не знаете язык, который будет использоваться.
К счастью, вы можете использовать ключевое слово start
для выравнивания текста по начальной позиции строки в зависимости от направления текста. Это означает, что установка text-align-last
на start
будет выравнивать текст языков LTR по левому краю и выравнивать текст языков RTL по правому краю. Точно так же вы можете использовать значение end
для выравнивания текста по конечной позиции строки в зависимости от направления текста.Это приведет к выравниванию текста языков LTR по правому краю и выравниванию текста языков RTL по левому краю.
См. Pen text-align-last — Example 3 от SitePoint (@SitePoint) на CodePen.
Значение по умолчанию для этого свойства — авто
. В этом случае текст внутри последней строки выравнивается с использованием значения свойства text-align
, если для параметра text-align
не установлено значение выравнивание по ширине
. Если установлено значение с выравниванием по ширине
, текст будет выровнен только в том случае, если значение свойства с выравниванием текста по ширине
установлено равным распространить
.В противном случае текст выравнивается по началу.
Очки, заслуживающие внимания
В спецификации говорится, что для свойства text-align
должно быть установлено значение justify
для работы text-align-last
. Однако, похоже, только IE и Edge реализуют это правило. Свойство работает как в Firefox, так и в Chrome без установки выравнивания текста
на выравнивания
. В следующей демонстрации весь текст должен быть выровнен по правому краю в Edge и IE. В других браузерах последние строки будут выровнены на основе значения text-align-last
, а остальные строки будут выровнены по правому краю.
См. Pen text-align-last — Example 4 от SitePoint (@SitePoint) на CodePen.
Вам может показаться, что результаты не такие привлекательные, как при установке выравнивания текста
на выравнивания по ширине
. Таким образом, в большинстве случаев вы, вероятно, все равно будете выравнивать по ширине
текста.
Свойство по-прежнему работает, даже если разрыв строки вызван, скажем, тегом –
или чем-то в этом роде. Вы также должны иметь в виду, что это свойство будет выравнивать все последние строки текста внутри указанного элемента, а не только абсолютную последнюю строку содержимого.Например, если текст внутри элемента article
или div
имеет 3 абзаца, последняя строка каждого из них будет выровнена на основе text-align-last
.
Если вы намереваетесь просто выровнять абсолютную последнюю строку вашего контента, то в зависимости от ситуации вы можете использовать селектор : last-child
или : last-of-type
. В качестве примера возьмите код из демонстрации ниже:
артикул {
выравнивание текста: выравнивание;
}
article p: last-of-type {
выравнивание текста последний: право;
}
Выравнивает последнюю строку последнего абзаца нашей статьи по правому краю.Остальные строки выравниваются на основе значения свойства text-align
.
См. Pen text-align-last — Example 5 от SitePoint (@SitePoint) на CodePen.
Точно так же вы также можете использовать другие селекторы, такие как : четный
и : нечетный
, для попеременного изменения выравнивания.
Иногда у вас будет контент, в котором последняя строка и первая строка абзаца совпадают. Другими словами, в абзаце всего одна строка. В этом случае, если вы указали значения для свойства text-align
и text-align-last
, свойство text-align-last
будет иметь приоритет.Единственное исключение — когда text-align
указывает явное выравнивание первой строки
с использованием значения «start end».
Рассмотрим фрагмент кода ниже:
p {
выравнивание текста: выравнивание;
}
p: nth-of-type (2) {
выравнивание текста последний: слева;
}
Если второй абзац в этом случае состоит только из одной строки, тогда текст будет выровнен по левому краю, а не по ширине, потому что text-align-last
будет иметь приоритет. Демо ниже показывает приведенный выше CSS в действии вместе с двумя другими примерами.
См. Pen text-align-last — Example 6 от SitePoint (@SitePoint) на CodePen.
Поддержка браузера
Рассмотрев все важные аспекты этого свойства, давайте обсудим поддержку браузера. Поддержка этого свойства может быть включена с помощью «Включить экспериментальные функции веб-платформы» как в Chrome, так и в Opera, начиная с версий 35 и 22 соответственно. Он полностью поддерживается Chrome и Opera начиная с версий 47 и 34.
Чтобы использовать это свойство в Firefox, вам необходимо использовать версию с префиксом -moz-
.Значения начало
и конец
не поддерживаются Internet Explorer. Однако Edge полностью поддерживает это свойство. Одним из примечательных браузеров, который вообще не поддерживает text-align-last
, является Safari. Вы можете узнать больше о поддержке браузеров здесь.
При общей поддержке 61,85% не помешает начать использовать это свойство. Пользователи с неподдерживаемыми браузерами никакой разницы не заметят.
Заключение
Хотя вы можете использовать text-align-last
для правильного выравнивания текста в вашей статье, еще один интересный вариант использования — это правильно выровнять многострочные подписи ваших изображений.Если у вас есть какие-либо другие варианты использования этого свойства или у вас есть какие-либо вопросы, поделитесь ими с нами в комментариях.
Учебное пособие по выравниванию CSS с примерами
Не существует общего правила выравнивания элемента, поэтому вы должны предложить подходящее решение в зависимости от ситуации. В этом посте я дам несколько сценариев и решений для выравнивания элемента.
Горизонтальное выравнивание
Выравнивание по горизонтали означает способ отображения элемента влево, по центру или вправо.
Вертикальное выравнивание
Вертикальное выравнивание означает способ отображения элемента сверху, посередине или снизу.
Если у вас есть элемент Block, например
Вам необходимо установить размер ширины элемента на определенное число или процентное значение (%), но оно должно быть меньше 100%, что гарантирует, что элемент не займет все горизонтальное пространство элемента, содержащего его.
И примените к нему CSS margin: auto
маржа слева: авто;
маржа-право: авто;
/* ИЛИ: */
маржа: авто;
Примечание: CSS margin-top: auto и CSS margin-bottom: auto не действуют как вертикальное выравнивание.
h-align-block-example.html
Выравнивание CSS
<стиль>
.center {
маржа слева: авто;
маржа-право: авто;
ширина: 180 пикселей;
граница: сплошной зеленый цвет 3px;
отступ: 10 пикселей;
}
Выровнять по горизонтали - по центру
<час />
маржа слева: авто;
маржа-право: авто;
ширина: 180 пикселей;
граница: сплошной зеленый цвет 3px;
отступ: 10 пикселей;
Свойство CSS text-align используется для элемента блока или ячейки таблицы, чтобы выровнять по горизонтали его встроенное содержимое.
Когда CSS text-align применяется к элементу, он работает со всем встроенным содержимым этого элемента, например текстовым содержимым, дочерними элементами, такими как ,. Но это не работает с дочерними элементами текущего элемента.
CSS свойство выравнивания текста
Примеры
Элементы
h2, h3 и h4 задают выравнивание текста:
h2 {text-align: center}
h3 {text-align: left}
h4 {text-align: right}
попробуйте «
In внизу этой страницы вы найдете больше примеров.
Определения атрибутов и инструкции
атрибут text-align определяет горизонтальное выравнивание текстового элемента.
По умолчанию: | влево, если направление равно ltr, и вправо, если направление равно RTL |
---|---|
наследование: | да |
версия: | CSS1 |
Синтаксис JavaScript: | объект. style.textAlign = «right» |
Поддержка браузера
Цифры в таблице представляют первый браузер, поддерживающий номер версии свойства.
Сразу после цифрового -webkit-, -ms- или -moz- ago в поддержку префикса атрибута первого номера версии браузера.
属性 | |||||
---|---|---|---|---|---|
выравнивание текста | 1,0 | 3,0 | 1,0 | 1,0 | 3,5 |
Значение свойства
значение | описание |
---|---|
слева | Выровнять текст по левому краю. |