#html #css #input #border #glow
#HTML #css #ввод #граница #свечение
Вопрос:
Я хочу создать несколько приличных входных данных для своей формы, и мне бы очень хотелось знать, как TWITTER создает светящуюся рамку вокруг своих входных данных.
Пример / изображение границы Twitter:
Я также не совсем понимаю, как создать закругленные углы.
Комментарии:
1. Вот руководство, которое научит вас, как: CSS эффекты свечения с помощью box-shadow
2. ссылка @Town, похоже, не работает: цикл перенаправления.
Ответ №1:
Поехали:
.glowing-border {
border: 2px solid #dadada;
border-radius: 7px;
}
.glowing-border:focus {
outline: none;
border-color: #9ecaed;
box-shadow: 0 0 10px #9ecaed;
}
Живая демонстрация: http://jsfiddle.net/simevidas/CXUpm/1/show /
(чтобы просмотреть код для демонстрации, удалите «показать /» из URL)
label {
display:block;
margin:20px;
width:420px;
overflow:auto;
font-family:sans-serif;
font-size:20px;
color:#444;
text-shadow:0 0 2px #ddd;
padding:20px 10px 10px 0;
}
input {
float:right;
width:200px;
border:2px solid #dadada;
border-radius:7px;
font-size:20px;
padding:5px;
margin-top:-10px;
}
input:focus {
outline:none;
border-color:#9ecaed;
box-shadow:0 0 10px #9ecaed;
}
<label> Aktuelles Passwort: <input type="password"> </label>
<label> Neues Passwort: <input type="password"> </label>
Комментарии:
1. Как я могу анимировать свечение?
2.@NSElvis, например
transition: box-shadow linear 1s
jsfiddle.net/simevidas/6LyWe/13. Очень красиво. Во-первых, если вы хотите, чтобы это применялось только к полям ввода текста, вам нужно ограничить выбор: ввод [тип = текст]: фокус, ввод [тип = пароль], ввод [тип = текстовое поле].
4. @MichaelKennedy В реальных приложениях этого было бы недостаточно. Стандартным подходом были бы классы, например
.glowing-input { … }
.5. Конечно, я хотел сказать, что это применялось к переключателям, кнопкам отправки и т.д., Которые могут быть нежелательными.
Ответ №2:
Как насчет чего-то подобного?.. http://jsfiddle.net/UnsungHero97/Qwpq4/1207 /
CSS
input {
border: 1px solid #4195fc; /* some kind of blue border */
/* other CSS styles */
/* round the corners */
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
/* make it glow! */
-webkit-box-shadow: 0px 0px 4px #4195fc;
-moz-box-shadow: 0px 0px 4px #4195fc;
box-shadow: 0px 0px 4px #4195fc; /* some variation of blue for the shadow */
}
Комментарии:
1. Это не облегчает ввод и вывод
2. и что? принятый ответ не обеспечивает простоту ввода. исходный вопрос (и мой ответ) был опубликован в 2011 году, и я почти уверен, что светящиеся границы Twitter также не уменьшались. кроме того, вопрос не сосредоточен на простоте ввода, скорее на том, как сделать границу светящейся с закругленными углами, на что я ответил. Я не думаю, что вы должны голосовать против меня только потому, что нет простого ввода
Ответ №3:
Используйте обычный синий border
, средний border-radius
и синий box-shadow
с указанием позиции 0 0
.
Ответ №4:
SLaks попал в самую точку, но вы, возможно, захотите просмотреть изменения для входных данных в CSS3 в целом. Закругленные углы и прямоугольная тень являются новыми функциями в CSS3 и позволят вам делать именно то, что вы ищете. Одна из моих личных любимых ссылок для CSS3 / HTML5 — это http://diveintohtml5.ep.io / .
Ответ №5:
Модифицированная версия с чуть менее яркой версией.
input {
/* round the corners */
//background-color: transparent;
border: 1px solid;
height: 20px;
width: 160px;
color: #CCC;
border-radius: 4px;
-moz-border-radius: 4px;
-webkit-border-radius: 4px;
}
input:focus {
outline:none;
border: 1px solid #4195fc;
/* create a BIG glow */
box-shadow: 0px 0px 5px #4195fc;
-moz-box-shadow: 0px 0px 5px #4195fc;
-webkit-box-shadow: 0px 0px 5px #4195fc;
}
Ответ №6:
Я объединил два предыдущих ответа (jsfiddle).
input {
/* round the corners */
border-radius: 4px;
-moz-border-radius: 4px;
-webkit-border-radius: 4px;
}
input:focus {
outline:none;
border: 1px solid #4195fc;
/* create a BIG glow */
box-shadow: 0px 0px 14px #4195fc;
-moz-box-shadow: 0px 0px 14px #4195fc;
-webkit-box-shadow: 0px 0px 14px #4195fc;
}
Ответ №7:
input[type="text"]{
@include transition(all 0.30s ease-in-out);
outline: none;
padding: 3px 0px 3px 3px;
margin: 5px 1px 3px 0px;
border: 1px solid #DDDDDD;
}
input[type="text"]:focus{
@include box-shadow(0 0 5px rgba(81, 203, 238, 1));
-webkit-box-shadow: 0px 0px 5px #007eff;
-moz-box-shadow: 0px 0px 5px #007eff;
box-shadow: 0px 0px 5px #007eff;
}
Ответ №8:
Ниже приведен код, который использует Bootstrap. Цвета немного отличаются, но концепция та же. Это если вы используете LESS для компиляции CSS:
// Form control focus state
//
// Generate a customized focus state and for any input with the specified color,
// which defaults to the `@input-focus-border` variable.
//
// We highly encourage you to not customize the default value, but instead use
// this to tweak colors on an as-needed basis. This aesthetic change is based on
// WebKit's default styles, but applicable to a wider range of browsers. Its
// usability and accessibility should be taken into account with any change.
//
// Example usage: change the default blue border and shadow to white for better
// contrast against a dark gray background.
.form-control-focus(@color: @input-border-focus) {
@color-rgba: rgba(red(@color), green(@color), blue(@color), .6);
amp;:focus {
border-color: @color;
outline: 0;
.box-shadow(~"inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px @{color-rgba}");
}
}
Если вы не используете LESS, то вот скомпилированная версия:
.form-control:focus {
border-color: #66afe9;
outline: 0;
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);
}
Ответ №9:
Это создаст светящиеся поля ввода и текстовые области:
textarea,textarea:focus,input,input:focus{
transition: border-color 0.15s ease-in-out 0s, box-shadow 0.15s ease-in-out 0s;
border: 1px solid #c4c4c4;
border-radius: 4px;
-moz-border-radius: 4px;
-webkit-border-radius: 4px;
box-shadow: 0px 0px 8px #d9d9d9;
-moz-box-shadow: 0px 0px 8px #d9d9d9;
-webkit-box-shadow: 0px 0px 8px #d9d9d9;
}
input:focus,textarea:focus {
outline: none;
border: 1px solid #7bc1f7;
box-shadow: 0px 0px 8px #7bc1f7;
-moz-box-shadow: 0px 0px 8px #7bc1f7;
-webkit-box-shadow: 0px 0px 8px #7bc1f7;
}
Ответ №10:
$('.form-fild input,.form-fild textarea').focus(function() {
$(this).parent().addClass('open');
});
$('.form-fild input,.form-fild textarea').blur(function() {
$(this).parent().removeClass('open');
});
.open {
color:red;
}
.form-fild {
position: relative;
margin: 30px 0;
}
.form-fild label {
position: absolute;
top: 5px;
left: 10px;
padding:5px;
}
.form-fild.open label {
top: -25px;
left: 10px;
/*background: #ffffff;*/
}
.form-fild input[type="text"] {
padding-left: 80px;
}
.form-fild textarea {
padding-left: 80px;
}
.form-fild.open textarea,
.form-fild.open input[type="text"] {
padding-left: 10px;
}
textarea,
input[type="text"] {
padding: 10px;
width: 100%;
}
textarea,
input,
.form-fild.open label,
.form-fild label {
-webkit-transition: all 0.2s ease-in-out;
-moz-transition: all 0.2s ease-in-out;
-o-transition: all 0.2s ease-in-out;
transition: all 0.2s ease-in-out;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="container">
<div class="row">
<form>
<div class="form-fild">
<label>Name :</label>
<input type="text">
</div>
<div class="form-fild">
<label>Email :</label>
<input type="text">
</div>
<div class="form-fild">
<label>Number :</label>
<input type="text">
</div>
<div class="form-fild">
<label>Message :</label>
<textarea cols="10" rows="5"></textarea>
</div>
</form>
</div>
</div>
Ответ №11:
Вам лучше использовать Twitter Bootstrap, который содержит все эти приятные материалы внутри. В частности, здесь именно то, что вы хотите.
Кроме того, вы можете использовать различные темы, созданные для Twitter Bootstrap с этого веб-сайта
Комментарии:
1. исправлена неработающая ссылка на формы начальной загрузки