Есть ли способ получить закругленные углы в контур div element
, аналогичный border-radius
?
Контур радиуса?
Ответ 1
Старый вопрос сейчас, но это может быть актуально для кого-то с подобной проблемой. У меня было поле ввода с закругленной border
и я хотел изменить цвет контура фокуса. Я не мог приручить ужасный квадратный outline
к элементу управления вводом.
Поэтому вместо этого я использовал box-shadow. Я на самом деле предпочел гладкий вид тени, но тень можно укрепить, чтобы имитировать округлый контур:
/* Smooth outline with box-shadow: */
.text1:focus {
box-shadow: 0 0 3pt 2pt red;
}
/* Hard "outline" with box-shadow: */
.text2:focus {
box-shadow: 0 0 0 2pt red;
}
<input type=text class="text1">
<br>
<br>
<br>
<br>
<input type=text class="text2">
Ответ 2
Обычно я выполняю это, используя псевдоэлемент: after:
конечно, это зависит от использования, этот метод позволяет контролировать отдельные границы, а не использовать метод жесткой тени.
Вы также можете установить смещения -1px и использовать фоновый линейный градиент (без рамки) для другого эффекта еще раз.
body {
margin: 20px;
}
a {
background: #999;
padding: 10px 20px;
border-radius: 5px;
text-decoration: none;
color: #fff;
position: relative;
border: 2px solid #000;
}
a:after {
content: '';
display: block;
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
border-radius: 5px;
border: 2px solid #ccc;
}
<a href="#">Button</a>
Ответ 3
Похоже на Lea Hayes выше, но вот как я это сделал:
div {
background: #999;
height: 100px;
width: 200px;
border: #999 solid 1px;
border-radius: 10px;
margin: 15px;
box-shadow: 0px 0px 0px 1px #fff inset;
}
<div></div>
Ответ 4
Вы ищете что-то вроде этого, я думаю.
div {
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
border: 1px solid black;
background-color: #CCC;
height: 100px;
width: 160px;
}
редактировать
В Firefox есть только -moz-outline-radius
, но он не будет работать в IE/Chrome/Safari/Opera/и т.д. Таким образом, похоже, что наиболее кросс-браузер-совместимый способ * получить изогнутую линию вокруг границы - использовать div-обертку:
div.inner {
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
border: 1px solid black;
background-color: #CCC;
height: 100px;
width: 160px;
}
div.outer {
display: inline-block;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
border: 1px solid red;
}
<div class="outer">
<div class="inner"></div>
</div>
Ответ 5
Я хотел получить хорошую доступность фокуса для выпадающих меню в навигационной панели Bootstrap, и был очень доволен этим:
a.dropdown-toggle:focus {
display: inline-block;
box-shadow: 0 0 0 2px #88b8ff;
border-radius: 2px;
}
<a href="https://stackoverflow.com" class="dropdown-toggle">Visit Stackoverflow</a>
Ответ 6
Я только нашел отличное решение для этого, и, посмотрев все ответы до сих пор, я еще не видел его опубликованным. Итак, вот что я сделал:
Я создал правило CSS для класса и использовал псевдокласс для: focus для этого правила. Я изложил outline: none
не избавился от этого "голубого" нестандартного "контура", используемого по умолчанию, который по умолчанию использует Chrome. Затем, в том же :focus
псевдокласс, где этот контур больше не существует, я добавил свои свойства радиуса и границы. Следуя следующему
outline: none;
border-radius: 5px;
border: 2px solid maroon;
иметь контур бордового цвета с радиусом границы, который теперь появляется, когда элемент выбирается вкладкой пользователем.
Ответ 7
Я знаю, что он имеет в виду...
Если вы хотите получить рельефный вид, вы можете сделать что-то вроде следующего:
.embossed {
background: #e5e5e5;
height: 100px;
width: 200px;
border: #FFFFFF solid 1px;
outline: #d0d0d0 solid 1px;
margin: 15px;
}
.border-radius {
border-radius: 20px 20px 20px 20px;
-webkit-border-radius: 20px;
-moz-border-radius: 20px;
-khtml-border-radius: 20px;
}
.outline-radius {
-moz-outline-radius: 21px;
}
<div class="embossed"></div>
<div class="embossed border-radius"></div>
<div class="embossed border-radius outline-radius">-MOZ ONLY</div>
Ответ 8
Существует решение, если вам нужен только контур без рамки. Это не мое. Я получил, если из файла Bootstrap css. Если вы укажете outline: 1px auto certain_color
, вы получите тонкую внешнюю линию вокруг div определенного цвета. В этом случае указанная ширина не имеет значения, даже если вы укажете ширину 10 px, в любом случае это будет тонкая линия. Ключевое слово в указанном правиле - "авто".
Если вам нужен контур с закругленными углами и определенной шириной, вы можете добавить правило css на границе с необходимой шириной и одним цветом. Он делает контур толще.
Ответ 9
Нет. Границы сидят снаружи элемента и на внутренней части области поля коробки. Контуры сидят внутри элемента, а область заполнения коробки-типа игнорирует его. Он не предназначен для эстетики. Это просто показать дизайнеру очертания элементов. На ранних этапах разработки html-документа, например, разработчику, возможно, потребуется быстро разглядеть, если они поместили все скелетные divs в нужное место. Позже им, возможно, потребуется проверить, являются ли разные кнопки и формы правильным числом пикселей друг от друга.
Границы эстетичны по своей природе. В отличие от контуров они фактически отделены от box-model, что означает, что они не перекрывают текст, установленный в margin: 0; и каждая сторона границы может быть индивидуально оформлена.
Если вы пытаетесь применить радиус угла к контуру, я предполагаю, что вы используете его так, как большинство людей используют границу. Итак, если вы не возражаете, чтобы я спросил, какое свойство контура делает его желательным по границе?
Ответ 10
КОМБИНИРОВАННАЯ КОРОБКА И ТЕМА.
Небольшой поворот на ответ Lea Hayes, который я нашел
input[type=text]:focus {
box-shadow: 0 0 0 1pt red;
outline-width: 1px;
outline-color: red;
}
получает действительно хорошую чистоту. Никаких прыжков в размерах, которые вы получаете при использовании пограничного радиуса
Ответ 11
Я просто установил прозрачность контура.
input[type=text] {
outline: rgba(0, 0, 0, 0);
border-radius: 10px;
}
input[type=text]:focus {
border-color: #0079ff;
}
Ответ 12
Попробуйте использовать прописку и цвет фона для рамки, затем рамку для контура:
.round_outline {
padding: 8px;
background-color: white;
border-radius: 50%;
border: 1px solid black;
}
Работал в моем случае.
Ответ 13
Для Firefox существует -mozilla-outline-radius. Но это нестандартно.
Ответ 14
Мне нравится этот способ.
.circle:before {
content: "";
width: 14px;
height: 14px;
border: 3px solid #fff;
background-color: #ced4da;
border-radius: 7px;
display: inline-block;
margin-bottom: -2px;
margin-right: 7px;
box-shadow: 0px 0px 0px 1px #ced4da;
}
Это создаст серый круг с остроумие вокруг него и снова 1px вокруг границы!
Ответ 15
clip-path: circle(100px at center);
Это на самом деле сделает кликабельный только круг, в то время как border-radius все еще делает квадрат, но выглядит как круг.