Как задать ширину input в css
Перейти к содержимому

Как задать ширину input в css

  • автор:

Ширина input блока в html

Есть простой input блок Когда подобный input отображается в браузере , его рамка намного больше чем значение value,и тем более если ввести еще меньшее по длине слово. Понятно что размер рамки можно изменить меняя size под свои нужды

input[type=text]

Вопрос! Можно ли заставить без js, рамку input принимать размер в зависимости от количества букв в значении value, побывал width: auto в css; Не работает.

Отслеживать
задан 7 сен 2020 в 17:29
Андрей Солуянов Андрей Солуянов
705 5 5 серебряных знаков 16 16 бронзовых знаков

нативно — нет. Можно js выкрутиться, но будут проблемы с определение ширины текста. Вы уверены, что вам это нужно?)

7 сен 2020 в 17:32
7 сен 2020 в 17:33

Если не принципиально использовать именно input, это можно провернуть с другими элементами с inline-block и contenteditable

7 сен 2020 в 17:35

Спасибо ребят. И Nikita Umnov и UModeL. В нативном варианте как я и предполагал такой штуки нет. Придется делать с js ,по ссылки что прислал UModeL, второй вариант с contenteditable интересен но имеет нюанс, если нажать enter то каретка перепрыгивает на вторую строку и делает input уже многострочным что не всегда имеет место быть. Но вариант с js очень короткий и у меня в голове он был на много длинней. Раз без js не выходит значит буду через js делать. Такая штука может понадобиться при переименовании чего либо. Например названия, папки, файла.Всем всех благ!!

Как настроить ширину input в форме с bootstrap 3?

Форма отображается красиво, input-ы с закруглениями, тенями и т.п. Благодаря классу .form-control , однако в официальной документации написано:

All textual input, textarea, and select elements with .form-control are set to width: 100%; by default.

Все остальное в форме устраивает. Нашел способ с колонками Если к div с классом control-group я добавляю, например, класс col-xs-3 , его ширина меняется, однако все поля выстраиваются в горизонтальную линию как здесь
Но мне нужна вертикальная форма с полями не на 100% ширины, как ее сделать, сохранив остальные свойства оформления из класса .form-control ?

Отслеживать
задан 6 окт 2015 в 13:39
950 1 1 золотой знак 11 11 серебряных знаков 41 41 бронзовый знак

@Alex к сожалению, проблема пока не решена. В Вашем примере кнопка и поле ввода имеют одинаковую ширину. Причем кнопка по верстке вылезает за инпут. Необходимо оформление аналогично тому, что в примере jsfiddle.net/384n7njn/1 т.е. ширина кнопки не равняется ширине инпутов. Однако общая ширина формы не должна быть 100% от ширины страницы.

9 окт 2015 в 14:16

@Alex 100% инпут не нужен. Проблема изначально в том, что форма растягивается на 100% страницы.Поле для ввода логина, нецелесообразно делать таким. Так же, как и в Вашем 1 примере растягивать кнопку одновременно с полями ввода. Если посмотреть на форму, которую мы используем здесь для комментариев, если бы кнопка Комментировать располагалась под полем ввода текста, вряд ли бы она растягивалась вместе с ним по ширине. Ваш 2 пример ближе к истине, если заменить, скажем, col-xs-12 на col-xs-5 . Однако мне кажется, что в Вашем коде потерян

. Поэтому не могу понять, как это работает)

Установите ширину текстового поля ввода в HTML, CSS и JavaScript

В этом посте мы обсудим, как установить ширину текстового поля ввода в HTML, CSS и JavaScript.

1. Установите ширину в HTML

В HTML вы можете использовать width Атрибут для установки ширины элемента.

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

2. Установите ширину с помощью CSS

Хорошей практикой является отделение разметки CSS от разметки HTML. Идея состоит в том, чтобы определить класс для установки width Свойство CSS.

HTML

CSS

width : 200px ;

Кроме того, вы также можете использовать селектор CSS текстового поля ввода для установки width Свойство CSS.

HTML

CSS

input[type=»text»] < width : 200px ;

3. Установите ширину с помощью JavaScript

С помощью JavaScript вы можете использовать setAttribute() способ установить значение size атрибут в текстовом поле ввода.


document . getElementById ( «name» ) . setAttribute ( ‘size’ , ’20’ ) ;

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

JS

$ ( document ) . ready ( function ( ) < $ ( '#name' ) . keyup ( function ( ) < $ ( this ) . attr ( 'size' , $ ( this ) . val ( ) . length )

HTML

Это все, что касается установки ширины текстового поля ввода в HTML, CSS и JavaScript.

Оценить этот пост

Средний рейтинг 4.02 /5. Подсчет голосов: 86

Голосов пока нет! Будьте первым, кто оценит этот пост.

Сожалеем, что этот пост не оказался для вас полезным!

Расскажите, как мы можем улучшить этот пост?

Спасибо за чтение.

Пожалуйста, используйте наш онлайн-компилятор размещать код в комментариях, используя C, C++, Java, Python, JavaScript, C#, PHP и многие другие популярные языки программирования.

Как мы? Порекомендуйте нас своим друзьям и помогите нам расти. Удачного кодирования 🙂

Подписывайся
2 Комментарии
Большинство голосов
Новейшие Самый старый
Встроенные отзывы
Просмотреть все комментарии
Просмотр комментариев
Загрузить больше комментариев
Просматривать
Подпишитесь на новые публикации

  • Все проблемы
  • Практика DSA
  • 100 самых популярных задач
  • 50 лучших классических задач
  • Лучшие алгоритмы
  • Компилятор С/С++
  • Компилятор Java
  • Компилятор Python
  • Компилятор JavaScript
  • компилятор PHP
  • Компилятор C#
  • Свяжитесь с нами
  • Политика конфиденциальности
  • условия обслуживания
  • Подпишитесь на новые публикации

Techie Delight © 2023 Все права защищены.

Этот веб-сайт использует файлы cookie. Используя этот сайт, вы соглашаетесь с использованием файлов cookie, нашей политикой, условиями авторского права и другими условиями. Читайте наши Политика конфиденциальности. Понятно

Стилизуем формы при помощи CSS: руководство для начинающих

Подпишись на наш телеграм-канал TechRocks WEB-разработка?

Перевод статьи «How to style forms with CSS: A beginner’s guide».

Приложения получают данные от пользователей, в основном, через формы. Возьмем для примера обычную форму регистрации. Там всегда будет несколько полей, куда пользователь может ввести нужную информацию (свое имя, email и т. д.).

Раньше на сайтах были простые, скучные HTML-формы без всякой стилизации. Но с появлением CSS все изменилось. Благодаря новейшим свойствам CSS мы сейчас можем создавать куда более интересные и красивые формы.

И это не мое личное мнение. На иллюстрации ниже вы видите, как выглядит обычная HTML-форма без CSS.

А вот та же форма, в оформлении которой использовали каскадные таблицы стилей.

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

Наше руководство по стилизации форм при помощи CSS будет состоять из шести пунктов.

  1. Определение размеров формы (box-sizing).
  2. Селекторы CSS для элементов ввода (input).
  3. Базовые методы стилизации для текстовых полей ввода.
  4. Стилизация прочих полей ввода.
  5. Псевдоклассы UI.
  6. Элементы ввода, недоступные для кастомизации.

Прежде чем мы углубимся в нашу тему, важно понять, что нет никаких особенных стилей для форм. Ваши возможности в этом плане ограничены только вашим воображением. Это руководство лишь поможет вам начать создавать собственные уникальные варианты дизайна при помощи CSS.

1. Устанавливаем box-sizing

Я обычно устанавливаю * не только для форм, но и для веб-страниц. Благодаря этому ширина (width) всех элементов будет содержать внутренние отступы (padding).

.some-class

Ширина .some-class без box-sizing:border-box будет больше 200px, что может стать проблемой. Поэтому большинство разработчиков используют border-box для всех элементов.

Ниже приведена улучшенная версия нашего первоначального кода. В нее также добавлены псевдоэлементы :before и :after.

*, *:before, *:after

Совет: универсальный селектор * выбирает все элементы в документе.

2. Селекторы CSS для элементов ввода

Самый простой способ выбрать элементы ввода — использовать селекторы атрибутов.

input[type=text] < // input elements with type="text" attribute >input[type=password] < // input elements with type="password" attribute >

Эти селекторы будут выбирать все элементы ввода в документе. Если вам нужно выбрать какие-то специфические селекторы, следует добавить классы:

.signup-text-input < // styles here >

3. Базовые методы стилизации для однострочных текстовых полей ввода

Чаще всего поля ввода в формах бывают однострочными. Обычно такое поле представляет собой простой блок с границей (его вид зависит от браузера).

Вот HTML-разметка для однострочного текстового поля с плейсхолдером.

Выглядеть это будет так:

Чтобы сделать это текстовое поле более привлекательным, можно использовать следующие свойства CSS:

  • Padding (внутренние отступы)
  • Margin (внешние отступы)
  • Border (граница)
  • Box shadow (тень блока)
  • Border radius (для скругления границ)
  • Width (ширина)
  • Font (шрифт)

Давайте пройдемся по каждому из этих свойств.

Padding

Добавление некоторого внутреннего пространства может повысить четкость. Чтобы это сделать, применяем свойство padding.

input[type=text]

Margin

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

input[type=text] < padding:10px; margin:10px 0; // add top and bottom margin >

Border

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

.border-customized-input
.border-removed-input

Совет: если убираете границу, обязательно добавьте цвет фона или тень. В противном случае пользователь просто не увидит ваше поле.

Некоторые веб-дизайнеры предпочитают оставлять только нижнюю границу. При таком варианте пользователь как бы будет писать на строчке, как в блокноте.

.border-bottom-input < border:0; // remove default border border-bottom:1px solid #eee; // add only bottom border >
Box shadow

Свойство CSS box-shadow позволяет добавить тень элемента. Меняя 5 значений этого свойства, вы сможете добиться самых разнообразных эффектов.

input[type=text]

Border radius

Свойство border-radius может очень сильно изменить вид ваших форм. Поля для ввода текста, имеющие скругление углов, выглядят совсем иначе.

.rounded-input

Комбинируя box-shadow и border-radius, вы можете существенно изменить вид полей.

Width

Используйте свойство width, чтобы установить ширину поля ввода.

input

Font

Большинство браузеров используют разные семейства шрифтов и размер шрифта для элементов форм. Если необходимо, можно установить наследование шрифта от документа.

input, textarea

4. Стилизация прочих типов полей ввода

Вы также можете прописывать стили и для других полей — области текста, радиокнопок, чек-боксов и пр.

Давайте рассмотрим подробнее каждое из них.

Текстовые области (text areas)

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

Также для текстовых областей применимо и очень полезно свойство resize. В большинстве браузеров текстовые области по умолчанию могут растягиваться как по оси x, так и по оси y (значение: both). Но вы можете установить для этого свойства также значение horizontal или vertical.

Посмотрите на пример:

Здесь я использовал resize:vertical, чтобы разрешить изменение размера исключительно по вертикали. Такая практика применяется в большинстве форм, поскольку позволяет избежать появления горизонтальной полосы прокрутки.

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

Чекбоксы и радиокнопки

Дефолтные чекбоксы и радиокнопки очень сложно стилизовать, для этого требуется более сложный CSS-код (и HTML — тоже).

Для стилизации чекбокса используйте следующий HTML-код.

Несколько вещей, на которые нужно обратить внимание:

  • Поскольку мы используем в качестве обертки для , если вы кликнете на любой элемент внутри , «кликнутым» будет .
  • Мы спрячем , потому что браузеры практически не позволяют нам его модифицировать.
  • создает пользовательский чекбокс.
  • Чтобы получить положение «отмечено» и стилизовать пользовательский чекбокс, мы будем использовать псевдокласс input:checked.

Вот пользовательский чекбокс (комментарии в CSS-коде поясняют происходящее более подробно):

See the Pen yLNKQBo by Supun Kavinda (@SupunKavinda) on CodePen.

Вот пользовательская радиокнопка:

See the Pen eYNMQNM by Supun Kavinda (@SupunKavinda) on CodePen.

В обоих примерах мы использовали одну и ту же концепцию (input:checked).

В браузерах чекбоксы отображаются квадратиками, а радиокнопки — кружочками. Это лучше не менять, чтобы не путать пользователя.

Раскрывающийся список

Раскрывающийся список позволяет пользователю выбрать элемент из нескольких предложенных вариантов.

 

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

select

Но вы не можете стилизовать выпадающие элементы, потому что их стили зависят от операционной системы. Единственный способ изменить их вид — использовать JavaScript.

Кнопки

Как и у большинства элементов, у кнопок есть стили, установленные по умолчанию.

Давайте немного украсим нашу кнопку.

button < /* remove default behavior */ appearance:none; -webkit-appearance:none; /* usual styles */ padding:10px; border:none; background-color:#3F51B5; color:#fff; font-weight:600; border-radius:5px; width:100%; >

5. Псевдоклассы UI

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

Эти псевдоклассы могут использоваться для показа уведомлений в зависимости от атрибутов элемента:

  • :required
  • :valid и :invalid
  • :checked (этим мы уже пользовались)

Эти могут использоваться для создания эффектов для каждого состояния:

Сообщения, генерируемые при помощи :required

Показываем сообщение о том, что заполнение поля является обязательным:

Name Email label < display:block; >input:required + span:after

Если вы удалите атрибут required при помощи JavaScript, сообщение «Required» исчезнет автоматически.

Примечание: не может содержать другие элементы. А значит, и псевдоэлементы :after или :before. Поэтому нам нужно использовать другой элемент — .

Мы можем сделать то же самое с псевдоклассами :valid и :invalid.

:hover и :focus

:hover выбирает элемент, когда на него наводится курсор мыши. :focus выбирает элемент, когда тот в фокусе.

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

Вот несколько эффектов наведения для элементов формы (попробуйте навести курсор на разные поля):

See the Pen yLNKZqg by Supun Kavinda (@SupunKavinda) on CodePen.

Когда пользователь видит небольшие изменения в элементе, происходящие при наведении мыши, он понимает, что с элементом можно что-то делать. Это важно для дизайна элементов форм.

Вы замечали, что в некоторых браузерах вокруг элемента, находящегося в фокусе, появляется синяя внешняя граница? Вы можете использовать псевдокласс :focus, чтобы удалить ее и добавить другие эффекты для элемента в фокусе.

Следующий код удаляет внешнюю границу для всех элементов:

*:focus

Добавляем внешнюю границу для элементов в фокусе:

input[type=text]:focus < background-color: #ffd969; border-color: #000; // and any other style >

6. Элементы ввода, недоступные для кастомизации

Стилизация элементов форм всегда была сложной задачей. Есть некоторые элементы, с которыми не многое можно сделать в плане изменения стиля. Например:

Эти элементы предоставляются браузером и стилизуются в зависимости от вашей ОС. Единственный способ изменить их стиль — использовать кастомные контролы (Custom Controls), созданные при помощи div, span и прочих HTML-элементов, поддающихся стилизации.

Например, чтобы стилизовать , мы можем спрятать дефолтный input и использовать пользовательскую кнопку.

Кастомные контролы для элементов форм уже разработаны для основных JavaScript-библиотек. Найти их можно на GitHub.

Заключение

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

В качестве совета напоследок: не забывайте делать все ваши формы отзывчивыми.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *