Контур радиуса?

Есть ли способ получить закругленные углы в контур 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;
}

Работал в моем случае.

Ответ 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 все еще делает квадрат, но выглядит как круг.