การควบคุมแบบฟอร์ม
ให้การควบคุมรูปแบบข้อความ เช่น<input>
s และ<textarea>
s อัปเกรดด้วยสไตล์ที่กำหนดเอง การปรับขนาด สถานะการโฟกัส และอื่นๆ
ตัวอย่าง
<div class="mb-3">
<label for="exampleFormControlInput1" class="form-label">Email address</label>
<input type="email" class="form-control" id="exampleFormControlInput1" placeholder="[email protected]">
</div>
<div class="mb-3">
<label for="exampleFormControlTextarea1" class="form-label">Example textarea</label>
<textarea class="form-control" id="exampleFormControlTextarea1" rows="3"></textarea>
</div>
ขนาด
กำหนดความสูงโดยใช้คลาสเช่น.form-control-lg
และ.form-control-sm
.
<input class="form-control form-control-lg" type="text" placeholder=".form-control-lg" aria-label=".form-control-lg example">
<input class="form-control" type="text" placeholder="Default input" aria-label="default input example">
<input class="form-control form-control-sm" type="text" placeholder=".form-control-sm" aria-label=".form-control-sm example">
พิการ
เพิ่มdisabled
แอตทริบิวต์บูลีนบนอินพุตเพื่อให้มีลักษณะเป็นสีเทา ลบเหตุการณ์ตัวชี้ และป้องกันการโฟกัส
<input class="form-control" type="text" placeholder="Disabled input" aria-label="Disabled input example" disabled>
<input class="form-control" type="text" value="Disabled readonly input" aria-label="Disabled input example" disabled readonly>
อ่านเท่านั้น
เพิ่มreadonly
แอตทริบิวต์บูลีนบนอินพุตเพื่อป้องกันการแก้ไขค่าของอินพุต readonly
อินพุตยังคงสามารถโฟกัสและเลือกได้ ในขณะที่disabled
อินพุตไม่สามารถทำได้
<input class="form-control" type="text" value="Readonly input here..." aria-label="readonly input example" readonly>
ข้อความธรรมดาแบบอ่านอย่างเดียว
หากคุณต้องการให้<input readonly>
องค์ประกอบในแบบฟอร์มของคุณจัดรูปแบบเป็นข้อความธรรมดา ให้แทนที่.form-control
ด้วย.form-control-plaintext
เพื่อลบการจัดรูปแบบฟิลด์เริ่มต้นของฟอร์ม และรักษารูปแบบที่ถูกต้องmargin
และpadding
.
<div class="mb-3 row">
<label for="staticEmail" class="col-sm-2 col-form-label">Email</label>
<div class="col-sm-10">
<input type="text" readonly class="form-control-plaintext" id="staticEmail" value="[email protected]">
</div>
</div>
<div class="mb-3 row">
<label for="inputPassword" class="col-sm-2 col-form-label">Password</label>
<div class="col-sm-10">
<input type="password" class="form-control" id="inputPassword">
</div>
</div>
<form class="row g-3">
<div class="col-auto">
<label for="staticEmail2" class="visually-hidden">Email</label>
<input type="text" readonly class="form-control-plaintext" id="staticEmail2" value="[email protected]">
</div>
<div class="col-auto">
<label for="inputPassword2" class="visually-hidden">Password</label>
<input type="password" class="form-control" id="inputPassword2" placeholder="Password">
</div>
<div class="col-auto">
<button type="submit" class="btn btn-primary mb-3">Confirm identity</button>
</div>
</form>
ไฟล์อินพุต
<div class="mb-3">
<label for="formFile" class="form-label">Default file input example</label>
<input class="form-control" type="file" id="formFile">
</div>
<div class="mb-3">
<label for="formFileMultiple" class="form-label">Multiple files input example</label>
<input class="form-control" type="file" id="formFileMultiple" multiple>
</div>
<div class="mb-3">
<label for="formFileDisabled" class="form-label">Disabled file input example</label>
<input class="form-control" type="file" id="formFileDisabled" disabled>
</div>
<div class="mb-3">
<label for="formFileSm" class="form-label">Small file input example</label>
<input class="form-control form-control-sm" id="formFileSm" type="file">
</div>
<div>
<label for="formFileLg" class="form-label">Large file input example</label>
<input class="form-control form-control-lg" id="formFileLg" type="file">
</div>
สี
ตั้งค่าtype="color"
และเพิ่ม.form-control-color
ไปยัง<input>
. เราใช้คลาสตัวแก้ไขเพื่อตั้งค่าheight
s คงที่ และแทนที่ความไม่สอดคล้องกันระหว่างเบราว์เซอร์
<label for="exampleColorInput" class="form-label">Color picker</label>
<input type="color" class="form-control form-control-color" id="exampleColorInput" value="#563d7c" title="Choose your color">
ดาต้าลิสต์
Datalists ช่วยให้คุณสร้างกลุ่มของ<option>
s ที่สามารถเข้าถึงได้ (และเติมข้อความอัตโนมัติ) จากภายใน<input>
ไฟล์ . สิ่งเหล่านี้คล้ายกับ<select>
องค์ประกอบ แต่มาพร้อมกับข้อจำกัดและความแตกต่างของสไตล์เมนูที่มากขึ้น แม้ว่าเบราว์เซอร์และระบบปฏิบัติการส่วนใหญ่จะรองรับ<datalist>
องค์ประกอบบางส่วน แต่สไตล์ของพวกมันก็ไม่สอดคล้องกันอย่างดีที่สุด
เรียนรู้เพิ่มเติมเกี่ยวกับการรองรับองค์ประกอบดาต้าลิสต์
<label for="exampleDataList" class="form-label">Datalist example</label>
<input class="form-control" list="datalistOptions" id="exampleDataList" placeholder="Type to search...">
<datalist id="datalistOptions">
<option value="San Francisco">
<option value="New York">
<option value="Seattle">
<option value="Los Angeles">
<option value="Chicago">
</datalist>
ซาส
ตัวแปร
$input-*
มีการแชร์กับส่วนควบคุมแบบฟอร์มส่วนใหญ่ของเรา (ไม่ใช่ปุ่ม)
$input-padding-y: $input-btn-padding-y;
$input-padding-x: $input-btn-padding-x;
$input-font-family: $input-btn-font-family;
$input-font-size: $input-btn-font-size;
$input-font-weight: $font-weight-base;
$input-line-height: $input-btn-line-height;
$input-padding-y-sm: $input-btn-padding-y-sm;
$input-padding-x-sm: $input-btn-padding-x-sm;
$input-font-size-sm: $input-btn-font-size-sm;
$input-padding-y-lg: $input-btn-padding-y-lg;
$input-padding-x-lg: $input-btn-padding-x-lg;
$input-font-size-lg: $input-btn-font-size-lg;
$input-bg: $body-bg;
$input-disabled-color: null;
$input-disabled-bg: $gray-200;
$input-disabled-border-color: null;
$input-color: $body-color;
$input-border-color: $gray-400;
$input-border-width: $input-btn-border-width;
$input-box-shadow: $box-shadow-inset;
$input-border-radius: $border-radius;
$input-border-radius-sm: $border-radius-sm;
$input-border-radius-lg: $border-radius-lg;
$input-focus-bg: $input-bg;
$input-focus-border-color: tint-color($component-active-bg, 50%);
$input-focus-color: $input-color;
$input-focus-width: $input-btn-focus-width;
$input-focus-box-shadow: $input-btn-focus-box-shadow;
$input-placeholder-color: $gray-600;
$input-plaintext-color: $body-color;
$input-height-border: $input-border-width * 2;
$input-height-inner: add($input-line-height * 1em, $input-padding-y * 2);
$input-height-inner-half: add($input-line-height * .5em, $input-padding-y);
$input-height-inner-quarter: add($input-line-height * .25em, $input-padding-y * .5);
$input-height: add($input-line-height * 1em, add($input-padding-y * 2, $input-height-border, false));
$input-height-sm: add($input-line-height * 1em, add($input-padding-y-sm * 2, $input-height-border, false));
$input-height-lg: add($input-line-height * 1em, add($input-padding-y-lg * 2, $input-height-border, false));
$input-transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
$form-color-width: 3rem;
$form-label-*
และ$form-text-*
มีไว้สำหรับ ส่วนประกอบ <label>
และ.form-text
ส่วนประกอบของเรา
$form-label-margin-bottom: .5rem;
$form-label-font-size: null;
$form-label-font-style: null;
$form-label-font-weight: null;
$form-label-color: null;
$form-text-margin-top: .25rem;
$form-text-font-size: $small-font-size;
$form-text-font-style: null;
$form-text-font-weight: null;
$form-text-color: $text-muted;
$form-file-*
ใช้สำหรับใส่ไฟล์
$form-file-button-color: $input-color;
$form-file-button-bg: $input-group-addon-bg;
$form-file-button-hover-bg: shade-color($form-file-button-bg, 5%);