Metin türü giriş kutusuna bir glif ikonu nasıl ekleyebilirim? Örneğin, bir kullanıcı adı girişinde 'icon-user' olmasını istiyorum, şöyle bir şey:
Metin türü giriş kutusuna bir glif ikonu nasıl ekleyebilirim? Örneğin, bir kullanıcı adı girişinde 'icon-user' olmasını istiyorum, şöyle bir şey:
Yanıtlar:
Bir saniyede Bootstrap'a gideceğiz, ancak işte bunu kendiniz yapmak için temel CSS kavramları. Gibi yırtıcı sakal işaret , kesinlikle giriş elemanının simge içini konumlandırarak CSS ile bunu yapabilirsiniz. Ardından, metnin simgeyle çakışmaması için her iki tarafa da dolgu ekleyin.
Aşağıdaki HTML için:
<div class="inner-addon left-addon">
<i class="glyphicon glyphicon-user"></i>
<input type="text" class="form-control" />
</div>
Glifleri sola ve sağa hizalamak için aşağıdaki CSS'yi kullanabilirsiniz:
/* enable absolute positioning */
.inner-addon {
position: relative;
}
/* style icon */
.inner-addon .glyphicon {
position: absolute;
padding: 10px;
pointer-events: none;
}
/* align icon */
.left-addon .glyphicon { left: 0px;}
.right-addon .glyphicon { right: 0px;}
/* add padding */
.left-addon input { padding-left: 30px; }
.right-addon input { padding-right: 30px; }
Not : Bu , glifikon kullandığınızı varsayar , ancak font-awesome ile eşit derecede iyi çalışır .
FA için, sadece değiştirmek.glyphicon
ile.fa
Arabellek işaret ettiği gibi , bu isteğe bağlı Simgeler ile Doğrulama Durumları kullanılarak Bootstrap içinde doğal olarak yapılabilir . Bu, .form-group
öğeye sınıfı .has-feedback
ve simgesine sınıfı vererek yapılır .form-control-feedback
.
En basit örnek şöyle bir şey olurdu:
<div class="form-group has-feedback">
<label class="control-label">Username</label>
<input type="text" class="form-control" placeholder="Username" />
<i class="glyphicon glyphicon-user form-control-feedback"></i>
</div>
Artıları :
Eksileri :
Eksilerini aşmak için, bu çekme isteğini sola hizalanmış simgeleri desteklemek için değişikliklerle bir araya getirdim . Nispeten büyük bir değişiklik olduğundan, gelecekteki bir sürüme kadar ertelendi, ancak bugün bu özelliklere ihtiyacınız varsa , basit bir uygulama kılavuzu:
Sadece bu form değişikliklerini css'e ekleyin (ayrıca altta gizli yığın snippet'i ile satır içi)
* DAHA AZ : alternatif olarak, eğer daha azıyla inşa ediyorsanız , form değişiklikleri daha az
Sonra tek yapmanız gereken , simgeyi sola hizalamak için sınıfı .has-feedback-left
olan herhangi bir gruba sınıfı dahil etmektir .has-feedback
.
Farklı form türleri, farklı kontrol boyutları, farklı simge setleri ve farklı etiket görünürlükleri üzerinde birçok olası html yapılandırması olduğundan, canlı bir demo ile birlikte her permütasyon için doğru HTML setini gösteren bir test sayfası oluşturdum.
PS frizi önerisi ekleme
pointer-events: none;
olmuştur bootstrap eklendi
Aradığınızı bulamadınız mı? Benzer soruları deneyin:
.focusedInput
Sınıf sonrası tanımlanır .input-group-addon
Stil Sayfaları böylece zaman Cascade aşağı, ikincisi stilleri öncelikli olmalıdır. Senaryoyu daha iyi tanımlayabilir misin ki bu bir soruna yol açtı mı?
<i class="icon-user"></i>
için <i class="fa fa-user"></i>
. Harici kitaplıkları güncellemeyi düşündüğünüzde, uygulamanızın hala uyumlu olup olmadığını veya yeni sürüme geçirilmesi gerekip gerekmediğini belirlemek için sürüm notlarını ve yeni belgeleri okuduğunuzdan emin olun.
Resmi yöntemi. Özel CSS gerekmez:
<form class="form-inline" role="form">
<div class="form-group has-success has-feedback">
<label class="control-label" for="inputSuccess4"></label>
<input type="text" class="form-control" id="inputSuccess4">
<span class="glyphicon glyphicon-user form-control-feedback"></span>
</div>
</form>
DEMO: http://jsfiddle.net/LS2Ek/1/
Bu demo Bootstrap belgelerindeki bir örneğe dayanmaktadır. Burada "İsteğe Bağlı Simgelerle" aşağı kaydırın http://getbootstrap.com/css/#forms-control-validation
{left:0}
Glifikon sınıfına ekleme sola hizalanmaya dikkat etmelidir. jsfiddle.net/LS2Ek/30 . Anahat + kutu-gölge yaklaşımınızı seviyorum. Düzgün görünüyor!
left:0
artık girişin başlangıcını tanımlamaz. Ayrıca, girişin soluna dolgu eklemeniz ve sağdan kaldırmanız gerekir. Yine de, çok güzel ve temiz bir çözüm. Ben girdinin sol tanımlamak zor kısmı olduğunu düşünüyorum, hangi ile bir sarıcı position:relative
kullanışlı geliyor.
İşte sadece CSS alternatifi. Firefox'a benzer bir efekt elde etmek için bunu bir arama alanı için ayarladım (ve diğer yüz uygulama).
HTML
<div class="col-md-4">
<input class="form-control" type="search" />
<span class="glyphicon glyphicon-search"></span>
</div>
CSS
.form-control {
padding-right: 30px;
}
.form-control + .glyphicon {
position: absolute;
right: 0;
padding: 8px 27px;
}
Ben sadece varsayılan bootstrap CSS v3.3.1 kullanarak nasıl yaptım:
<div class="form-group">
<label class="control-label">Start:</label>
<div class="input-group">
<input type="text" class="form-control" aria-describedby="start-date">
<span class="input-group-addon" id="start-date"><span class="glyphicon glyphicon-calendar"></span></span>
</div>
</div>
Ve işte böyle görünüyor:
Bu 'hile', glyphicon sınıfının giriş denetimi için yazı tipini değiştireceği yan etkiyle çalışır.
<input class="form-control glyphicon" type="search" placeholder=""/>
Yan etkiden kurtulmak istiyorsanız, "glyphicon" sınıfını kaldırabilir ve aşağıdaki CSS'yi ekleyebilirsiniz (Yer tutucu sözde öğeyi biçimlendirmenin daha iyi bir yolu olabilir ve yalnızca Chrome'da test ettim).
.form-control[type="search"]::-webkit-input-placeholder:first-letter {
font-family:"Glyphicons Halflings";
}
.form-control[type="search"]:-moz-placeholder:first-letter {
font-family:"Glyphicons Halflings";
}
.form-control[type="search"]::-moz-placeholder:first-letter {
font-family:"Glyphicons Halflings";
}
.form-control[type="search"]:-ms-input-placeholder:first-letter {
font-family:"Glyphicons Halflings";
}
Muhtemelen daha temiz bir çözüm:
CSS
.form-control.glyphicon {
font-family:inherit;
}
.form-control.glyphicon::-webkit-input-placeholder:first-letter {
font-family:"Glyphicons Halflings";
}
.form-control.glyphicon:-moz-placeholder:first-letter {
font-family:"Glyphicons Halflings";
}
.form-control.glyphicon::-moz-placeholder:first-letter {
font-family:"Glyphicons Halflings";
}
.form-control.glyphicon:-ms-input-placeholder:first-letter {
font-family:"Glyphicons Halflings";
}
HTML
<input class="form-control glyphicon" type="search" placeholder=" search" />
<input class="form-control glyphicon" type="text" placeholder=" username" />
<input class="form-control glyphicon" type="password" placeholder=" password" />
Herhangi bir özel css olmadan resmi bootstrap 3.x sürümünden sınıflar kullanılarak yapılabilir.
input-group-addon
Girdi etiketinden önce kullanın , içinde input-group
glifikonlardan herhangi birini kullanın, işte kod
<form>
<div class="form-group">
<div class="col-xs-5">
<div class="input-group">
<span class="input-group-addon transparent"><span class="glyphicon glyphicon-user"></span></span>
<input class="form-control left-border-none" placeholder="User Name" type="text" name="username">
</div>
</div>
</div>
</form>
İşte çıktı
Özelleştirmek için kendi custom.css dosyanıza birkaç satır özel css ekleyin (gerekirse dolguyu ayarlayın)
.transparent {
background-color: transparent !important;
box-shadow: inset 0px 1px 0 rgba(0,0,0,.075);
}
.left-border-none {
border-left:none !important;
box-shadow: inset 0px 1px 0 rgba(0,0,0,.075);
}
Saydamın arka planını input-group-addon
yaparak ve giriş etiketinin sol eğimini sıfıra çevirerek, giriş kesintisiz bir görünüme sahip olacaktır. İşte özelleştirilmiş çıktı
İşte bir jsbin örneği
Bu, etiketlerle örtüşmenin, kullanırken hizalamanın input-lg
ve sekme sorununa odaklanmanın özel css sorunlarını çözecektir .
Burada, base64 URI kodlamasını kullanarak glificon'un görüntü temsilini doğrudan CSS'ye gömerek işaretlemenizi basitleştiren önyükleme olmayan bir çözümdür.
input {
border:solid 1px #ddd;
}
input.search {
padding-left:20px;
background-repeat: no-repeat;
background-position-y: 1px;
background-image: url();
}
<input class="search">
Fontawesome kullanıyorsanız bunu yapabilirsiniz:
<input type="text" style="font-family:Arial, FontAwesome" placeholder="" />
Sonuç
Unicode'un tam listesi Tam Font Awesome 4.6.3 simge başvurusunda bulunabilir
input {
border:solid 1px #ddd;
}
input.search {
padding-left:20px;
background-repeat: no-repeat;
background-position-y: 1px;
background-image: url();
}
<input class="search">
:before
CSS'de sözde elemanı kullanarak glificon yerleştirerek bunu yapmanın başka bir yolu .
Bu HTML için:
<form class="form form-horizontal col-xs-12">
<div class="form-group">
<div class="col-xs-7">
<span class="usericon">
<input class="form-control" id="name" placeholder="Username" />
</span>
</div>
</div>
</form>
Bu CSS'yi kullanın ( Bootstrap 3.x ve Webkit tabanlı tarayıcılar uyumlu )
.usericon input {
padding-left:25px;
}
.usericon:before {
height: 100%;
width: 25px;
display: -webkit-box;
-webkit-box-pack: center;
-webkit-box-align: center;
position: absolute;
content: "\e008";
font-family: 'Glyphicons Halflings';
pointer-events: none;
}
@Frizi'nin dediği gibi, pointer-events: none;
imlecin giriş odağına müdahale etmemesi için eklemeliyiz . Diğer tüm CSS kuralları, uygun boşlukları ortalamak ve eklemek içindir.
Sonuç:
Bir kullanıcı simgesi eklemek 
için placeholder
özelliğe veya istediğiniz yere ekleyin .
Bu kopya sayfasını kontrol etmek isteyebilirsiniz .
Misal:
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<input type="text" class="form-control" placeholder=" placeholder..." style="font-family: 'Glyphicons Halflings', Arial">
<input type="text" class="form-control" value=" value..." style="font-family: 'Glyphicons Halflings', Arial">
<input type="submit" class="btn btn-primary" value=" submit-button" style="font-family: 'Glyphicons Halflings', Arial">
Aşağıdaki kodu kullanarak girişin yazı tipini Glifikon'a ayarlamayı unutmayın:
font-family: 'Glyphicons Halflings', Arial
Burada Arial , girişteki normal metnin yazı tipidir.
Ayrıca Bootstrap 3.3.5 ile bu dava için bir karar var:
<div class="col-sm-5">
<label for="date">
<input type="date" placeholder="Date" id="date" class="form-control">
</label>
<i class="glyphicon glyphicon-calendar col-sm-pull-2"></i>
</div>
A alın form-control
ve is-valid
sınıfına ekleyin . Kontrolün yeşile döndüğüne dikkat edin, daha da önemlisi, kontrolün sağındaki onay işareti simgesine dikkat edin? İşte istediğimiz bu!
Misal:
.my-icon {
padding-right: calc(1.5em + .75rem);
background-image: url('https://use.fontawesome.com/releases/v5.8.2/svgs/regular/calendar-alt.svg');
background-repeat: no-repeat;
background-position: center right calc(.375em + .1875rem);
background-size: calc(.75em + .375rem) calc(.75em + .375rem);
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js"></script>
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet"/>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js"></script>
<div class="container">
<div class="col-md-5">
<input type="text" id="date" class="form-control my-icon" placeholder="Select...">
</div>
</div>
Yalnızca modern tarayıcılara ihtiyaç duyacak kadar şanslıysanız: css transform translate'i deneyin. Bu, sarmalayıcı gerektirmez ve giriş döndürücüyü kullanmak veya giriş tutamacının soluna taşımak için giriş [type = number] için daha fazla boşluk bırakabilmeniz için özelleştirilebilir.
@import url("//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css");
.is-invalid {
height: 30px;
box-sizing: border-box;
}
.is-invalid-x {
font-size:27px;
vertical-align:middle;
color: red;
top: initial;
transform: translateX(-100%);
}
<h1>Tasty Field Validation Icons using only css transform</h1>
<label>I am just a poor boy nobody loves me</label>
<input class="is-invalid"><span class="glyphicon glyphicon-exclamation-sign is-invalid-x"></span>
Bunu mevcut bootstrap sınıfları ve biraz özel stil ile yapabilmelisiniz.
<form>
<div class="input-prepend">
<span class="add-on">
<i class="icon-user"></i>
</span>
<input class="span2" id="prependedInput" type="text" placeholder="Username" style="background-color: #eeeeee;border-left: #eeeeee;">
</div>
Düzenle Simgeye icon-user
sınıf aracılığıyla başvurulur . Bu yanıt Bootstrap sürüm 2 sırasında yazılmıştır. Referansı aşağıdaki sayfada görebilirsiniz: http://getbootstrap.com/2.3.2/base-css.html#images