Plaukiojančios etiketės
Sukurkite gražiai paprastas formų etiketes, kurios sklando virš įvesties laukų.
Pavyzdys
<input class="form-control">
Apvyniokite ir <label>
elementų porą, .form-floating
kad įgalintumėte slankiąsias etiketes su „Bootstrap“ tekstinės formos laukais. A placeholder
būtinas kiekviename <input>
, nes mūsų tik CSS slankiųjų etikečių metodas naudoja :placeholder-shown
pseudoelementą. Taip pat atminkite, kad <input>
turi būti pirmoje vietoje, kad galėtume naudoti brolių ir seserų parinkiklį (pvz., ~
).
<div class="form-floating mb-3">
<input type="email" class="form-control" id="floatingInput" placeholder="[email protected]">
<label for="floatingInput">Email address</label>
</div>
<div class="form-floating">
<input type="password" class="form-control" id="floatingPassword" placeholder="Password">
<label for="floatingPassword">Password</label>
</div>
Kai value
jau yra apibrėžta, <label>
s automatiškai prisitaikys prie slankiosios padėties.
<form class="form-floating">
<input type="email" class="form-control" id="floatingInputValue" placeholder="[email protected]" value="[email protected]">
<label for="floatingInputValue">Input with value</label>
</form>
Formos patvirtinimo stiliai taip pat veikia taip, kaip tikėtasi.
<form class="form-floating">
<input type="email" class="form-control is-invalid" id="floatingInputInvalid" placeholder="[email protected]" value="[email protected]">
<label for="floatingInputInvalid">Invalid input</label>
</form>
Teksto sritys
Pagal numatytuosius nustatymus <textarea>
s with .form-control
bus tokio pat aukščio kaip <input>
s.
<div class="form-floating">
<textarea class="form-control" placeholder="Leave a comment here" id="floatingTextarea"></textarea>
<label for="floatingTextarea">Comments</label>
</div>
Jei norite nustatyti tinkintą aukštį <textarea>
, nenaudokite rows
atributo. Vietoj to, nustatykite aiškų height
(tiesioginį arba tinkintą CSS).
<div class="form-floating">
<textarea class="form-control" placeholder="Leave a comment here" id="floatingTextarea2" style="height: 100px"></textarea>
<label for="floatingTextarea2">Comments</label>
</div>
Parenka
Išskyrus .form-control
, slankiosios etiketės galimos tik .form-select
s. Jie veikia taip pat, bet skirtingai nei <input>
s, visada bus rodomi <label>
plūduriuojančioje būsenoje. Pasirinkimai su size
ir multiple
nepalaikomi.
<div class="form-floating">
<select class="form-select" id="floatingSelect" aria-label="Floating label select example">
<option selected>Open this select menu</option>
<option value="1">One</option>
<option value="2">Two</option>
<option value="3">Three</option>
</select>
<label for="floatingSelect">Works with selects</label>
</div>
Tik skaitomas paprastas tekstas
Slankiosios etiketės taip pat palaiko .form-control-plaintext
, kuri gali būti naudinga perjungiant iš redaguojamo <input>
į paprasto teksto reikšmę, nepažeidžiant puslapio išdėstymo.
<div class="form-floating mb-3">
<input type="email" readonly class="form-control-plaintext" id="floatingEmptyPlaintextInput" placeholder="[email protected]">
<label for="floatingEmptyPlaintextInput">Empty input</label>
</div>
<div class="form-floating mb-3">
<input type="email" readonly class="form-control-plaintext" id="floatingPlaintextInput" placeholder="[email protected]" value="[email protected]">
<label for="floatingPlaintextInput">Input with value</label>
</div>
Įvesties grupės
Plaukiojančios etiketės taip pat palaiko .input-group
.
<div class="input-group mb-3">
<span class="input-group-text">@</span>
<div class="form-floating">
<input type="text" class="form-control" id="floatingInputGroup1" placeholder="Username">
<label for="floatingInputGroup1">Username</label>
</div>
</div>
Naudojant .input-group
ir .form-floating
kartu su formos patvirtinimu, -feedback
turėtų būti už .form-floating
, bet viduje .input-group
. Tai reiškia, kad atsiliepimai turės būti rodomi naudojant javascript.
<div class="input-group has-validation">
<span class="input-group-text">@</span>
<div class="form-floating is-invalid">
<input type="text" class="form-control is-invalid" id="floatingInputGroup2" placeholder="Username" required>
<label for="floatingInputGroup2">Username</label>
</div>
<div class="invalid-feedback">
Please choose a username.
</div>
</div>
Išdėstymas
Dirbdami su Bootstrap tinklelio sistema, formos elementus būtinai įdėkite į stulpelių klases.
<div class="row g-2">
<div class="col-md">
<div class="form-floating">
<input type="email" class="form-control" id="floatingInputGrid" placeholder="[email protected]" value="[email protected]">
<label for="floatingInputGrid">Email address</label>
</div>
</div>
<div class="col-md">
<div class="form-floating">
<select class="form-select" id="floatingSelectGrid">
<option selected>Open this select menu</option>
<option value="1">One</option>
<option value="2">Two</option>
<option value="3">Three</option>
</select>
<label for="floatingSelectGrid">Works with selects</label>
</div>
</div>
</div>
Sass
Kintamieji
$form-floating-height: add(3.5rem, $input-height-border);
$form-floating-line-height: 1.25;
$form-floating-padding-x: $input-padding-x;
$form-floating-padding-y: 1rem;
$form-floating-input-padding-t: 1.625rem;
$form-floating-input-padding-b: .625rem;
$form-floating-label-opacity: .65;
$form-floating-label-transform: scale(.85) translateY(-.5rem) translateX(.15rem);
$form-floating-transition: opacity .1s ease-in-out, transform .1s ease-in-out;