ホームページ  >  記事  >  ウェブフロントエンド  >  Bootstrapフォームcomponent_html/css_WEB-ITnoseの詳細説明

Bootstrapフォームcomponent_html/css_WEB-ITnoseの詳細説明

WBOY
WBOYオリジナル
2016-06-24 11:19:491244ブラウズ

フォームの共通要素には主に、テキスト入力ボックス、ドロップダウン選択ボックス、ラジオ ボタン、チェック ボックス、テキスト フィールド、ボタンなどが含まれます。以下は、さまざまなブートストラップのバージョンです:

LESS:forms.less

SASS: _forms.scss

ブートストラップは、フォーム内のフィールドセット、凡例、およびラベルタグのみをカスタマイズします

fieldset {min-width: 0;padding: 0;margin: 0;border: 0;}legend {display: block;width: 100%;padding: 0;margin-bottom: 20px;font-size: 21px;line-height: inherit;color: #333;border: 0;border-bottom: 1px solid #e5e5e5;}label {display: inline-block;margin-bottom: 5px;font-weight: bold;}

これらのいくつかの要素に加えて、 input、select、textarea などの要素と同様に、クラス名 .form-control をカスタマイズすることで効果が得られます

1. 幅は 100% に設定されます (# ccc) ボーダー

3. 4 ピクセルの角を丸くします

4. 影の効果を設定し、要素がフォーカスされると、影と境界の効果が変化します

5. プレースホルダーの色を #999 に設定します

インラインフォーム

入力の前にラベルを追加したい場合、入力が別の行で折り返されます。そのようなラベルを追加する必要があり、入力を折り返さない場合は、次のように入力する必要があります。 form-group の場合も同様です。例:

<div class="form-group ">        <label class="sr-only">邮箱地址</label>    </div>    <div class="form-group">        <input type="email" class="form-control" placeholder="请输入邮箱号">    </div>

効果は次のとおりです:

インラインフォーム効果を実現するには、クラス名 .form-inline をフォームに追加するだけです。実装原理:

フォーム コントロールをインラインに設定する Inline-block 要素 (表示: inline-block) により、フォーム コントロールを 1 行で表示できます。

例:

<form class="form-inline">        <div class="form-group">            <label class="sr-only">邮箱</label>            <input class="form-control" type="email" placeholder="请输入邮箱号">        </div>        <div class="form-group">            <label class="sr-only">密码</label>            <input type="password" class="form-control" placeholder="请输入密码">        </div>        <div class="checkbox">            <label>                <input type="checkbox" > 记住密码            </label>        </div>        <div class="form-group">            <button class="btn btn-default">进入邮箱</button>        </div>    </form>

効果は次のとおりです:

上の図の効果を見て、コード内にラベル label があり、container.form には配置されていないことに気づきましたか? -group を指定すると、入力は折り返されません。さらに奇妙なのは、ラベル label の内容が表示されないことです。実際、よく見ると、ラベル label にはクラス名 .sr-only が追加されており、ラベルが非表示になっています。そのソース コードを見てみましょう。

.sr-only {position: absolute;width: 1px;height: 1px;padding: 0;margin: -1px;overflow: hidden;clip: rect(0, 0, 0, 0);border: 0;}

ラベル label が追加されました。 .sr専用クラスも追加されていますが、名前のラベルを隠す必要はありませんか? ? ?しかし、これはまさにブートストラップ フレームワークの利点であり、入力コントロールにラベルが設定されていない場合、スクリーン リーダーはそれを正しく認識できません。同時に、障害のある人に対して一定の配慮がなされています。

水平フォーム

ブートストラップで実装 水平フォーム効果は、次の 2 つの条件を満たす必要があります:

1. フォーム要素にクラス名 .form-horizo​​ntal を使用する 2. ブートストラップ フレームワークを使用したグリッド システム (詳細: Bootstrap グリッド システムの詳細な説明)

form 要素内 クラス名 .form-horizo​​ntal を使用して、主に次の機能があります:

1. フォーム コントロールのパディングとマージンの値を設定します

2.グリッド システムの行と同様に、.from-group の式を変更します

CSS ソース コード:

.form-horizontal .control-label,.form-horizontal .radio,.form-horizontal .checkbox,.form-horizontal .radio-inline,.form-horizontal .checkbox-inline {padding-top: 7px;margin-top: 0;margin-bottom: 0;}.form-horizontal .radio,.form-horizontal .checkbox {min-height: 27px;}.form-horizontal .form-group {margin-right: -15px;margin-left: -15px;}.form-horizontal .form-control-static {padding-top: 7px;}@media (min-width: 768px) {.form-horizontal .control-label {text-align: right;  }}.form-horizontal .has-feedback .form-control-feedback {top: 0;right: 15px;}

例:

<form class="form-horizontal">        <div class="form-group">            <label class="col-sm-2 control-label">邮箱</label>            <div class="col-sm-10">                <input type="email" class="form-control" placeholder="请输入邮箱">            </div>        </div>        <div class="form-group">            <label class="col-sm-2 control-label">密码</label>            <div class="col-sm-10">                <input type="password" class="form-control" placeholder="请输入密码">            </div>        </div>        <div class="form-group">            <div class="col-sm-10 col-sm-offset-2">                <label>                    <input type="checkbox">记住密码                </label>            </div>        </div>        <div class="form-group">            <div class="col-sm-10 col-sm-offset-2">                <button class="btn btn-default">进入邮箱</button>            </div>        </div>    </form>

効果は次のとおりです:

-ライン入力ボックス

ブートストラップで入力を使用する場合は、タイプ タイプも追加する必要があります。タイプ タイプが指定されていない場合、ブートストラップ フレームワークは input[type=” の形式でスタイルを定義するため、正しいスタイルを取得できません。 ?”]、例: input[type=”text”] に対応する text 型

<form role="form">    <div class="form-group">        <input type="email" class="form-control" placeholder="enter email" >    </div></form>

ドロップダウン選択ボックスを選択

複数の行を選択すると、複数の属性の値を複数に設定します

<form role="form"><div class="form-group">  <select class="form-control">    <option>1</option>    <option>2</option>    <option>3</option>    <option>4</option>    <option>5</option>  </select>  </div>  <div class="form-group">  <select multiple class="form-control">    <option>1</option>    <option>2</option>    <option>3</option>    <option>4</option>    <option>5</option>  </select></div></form>

textarea textarea

テキストエリアは同じように使用されますクラス名 .form-control が textarea 要素に追加されている場合は、.form 属性を設定する必要はありません。ブートストラップフレームワークでは -control スタイルのサブジェクトスペースの幅は 100% または auto

rrree

チェックボックスとラジオ

チェックボックスとラジオの場合、いくつかの小さな問題 (位置合わせなど) が発生しますラベル label と組み合わせて使用​​されます 質問)

<form role="form">        <div class="form-group">            <textarea  class="form-control" rows="3"></textarea>        </div>    </form>

1. チェックボックスとラジオは両方ともラベル

でラップされています 2. チェックボックスとラベルは .checkbox という名前のコンテナに配置されます

3. .radio という名前のコンテナ内で、ブートストラップは主に .checkbox と .radio スタイルを使用して、チェック ボックス、ラジオ ボタン、ラベルの配置を処理します

<form>        <div class="checkbox">            <label>                <input type="checkbox"> 记住密码            </label>        </div>        <div class="radio">            <label>                <input type="radio" name="optionsRadios" id="optionsRadios1" checked> 喜欢            </label>        </div>        <div class="radio">            <label>                <input type="radio" name="optionsRadios" id="optionsRadios2">不喜欢            </label>        </div>    </form>

チェック ボックスとラジオ ボタンは水平に配置されます

1 . チェックボックスを横に配置する必要がある場合は、ラベル label にクラス名.checkbox-inline を追加するだけです

2. ラジオを横に配置する必要がある場合は、ラベル label にクラス名.radion-inline を追加するだけです

以下は CSS ソースコードです:

.radio,.checkbox {display: block;min-height: 20px;padding-left: 20px;margin-top: 10px;margin-bottom: 10px;}.radio label,.checkbox label {display: inline;font-weight: normal;cursor: pointer;}.radio input[type="radio"],.radio-inline input[type="radio"],.checkbox input[type="checkbox"],.checkbox-inline input[type="checkbox"] {float: left;margin-left: -20px;}.radio + .radio,.checkbox + .checkbox {margin-top: -5px;}

.radio-inline,.checkbox-inline {display: inline-block;padding-left: 20px;margin-bottom: 0;font-weight: normal;vertical-align: middle;cursor: pointer;}.radio-inline + .radio-inline,.checkbox-inline + .checkbox-inline {margin-top: 0;margin-left: 10px;}

表单控件状态

1、焦点状态:

焦点状态是通过伪类:focus来实现的,bootstrap表单控件中的焦点状态删除了outline的默认样式,重新添加阴影效果,下面是css源码:

.form-control:focus {border-color: #66afe9;outline: 0;  -webkit-box-shadow: inset 0 1px 1pxrgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, .6);box-shadow: inset 0 1px 1pxrgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, .6);}

从源码中可以看出,要让控件在焦点状态下有上面的样式效果需要给控件添加类名.form-control

<form class="form-horizontal">        <div class="form-group ">            <div class="col-xs-6">                <input type="text" class=" input-lg" placeholder="不是在焦点状态下的效果">            </div>            <div class="col-xs-6">                <input type="text" class="form-control input-lg" placeholder="在焦点状态下的效果">            </div>        </div> </form>

file、radio、checkbox控件在焦点状态下的效果也与普通的input控件不太一样,下面是源码

input[type="file"]:focus,input[type="radio"]:focus,input[type="checkbox"]:focus {outline: thin dotted;outline: 5px auto -webkit-focus-ring-color;outline-offset: -2px;}

2、禁用状态:

在相应得表单控件上添加属性disabled即可,下面是css源码:

.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control {cursor: not-allowed;background-color: #eee;opacity: 1;}

input[type="radio"][disabled],input[type="checkbox"][disabled],.radio[disabled],.radio-inline[disabled],.checkbox[disabled],.checkbox-inline[disabled],fieldset[disabled] input[type="radio"],fieldset[disabled] input[type="checkbox"],fieldset[disabled] .radio,fieldset[disabled] .radio-inline,fieldset[disabled] .checkbox,fieldset[disabled] .checkbox-inline {cursor: not-allowed;}

例子:

<input type="text" class="form-control" placeholder="表单已禁用" disabled>

如果fieldset设置了disabled属性,整个域都会处于被禁用状态

例子:

<form role="form">        <fieldset disabled>            <div class="form-group">                <label> 输入框已禁用</label>                <input type="text" class="form-control" placeholder="禁止输入内容">            </div>            <div class="form-group">                <label>下拉框已禁用</label>                <select class="form-control">                    <option>1</option>                    <option>2</option>                    <option>3</option>                    <option>4</option>                </select>            </div>            <div class="checkbox">              <label >                  <input type="checkbox">选项框被禁用了              </label>            </div>            <button type="submit" class="btn btn-primary">提交</button>        </fieldset></form>

效果如下:(鼠标移上去的时候出现禁用的图标,这里是直接截的图看不到这个效果)

 

3、验证状态

bootstrap提供下面这几种效果:

1、.has-warning:警告状态  黄色

2、 .has-error :错误状态     红色

3、 .has-success:成功状态   绿色

使用的时候只需在form-group容器上对应添加状态类名,三种状态下效果都是一样的,只是颜色不一样而已

例子:

<form>        <div class="form-group has-success">          <label>成功状态</label>          <input type="text" class="form-control" placeholder="成功状态">        </div>        <div class="form-group has-error">            <label>错误状态</label>            <input type="text" class="form-control" placeholder="错误状态">        </div>        <div class="form-group has-warning">            <label>警告状态</label>            <input type="text" class="form-control" placeholder="警告状态">        </div>    </form>

效果如下:

有时候,在表单验证的时不同的状态会提供不同的icon,如果要在对应的状态下显示icon出来,只需要在对应的状态下添加类名.has-feedback ,注意它要和.has-error,.has-success,.has-warning一起使用。

bootstrap的小图标都是使用@font-face来制作的。如:009bdef44fc7c129b3e76dd942760f8e54bdf357c58b8a65c66d7c19c8e4d114

例子:

<form>        <div class="form-group has-success has-feedback">            <label> 成功状态</label>            <input type="text" class="form-control" placeholder="成功状态">            <span class="glyphicon glyphicon-ok form-control-feedback"></span>        </div>        <div class="form-group has-error has-feedback">            <label>错误状态</label>            <input type="text" class="form-control" placeholder="错误状态">            <span class="glyphicon glyphicon-remove form-control-feedback"></span>        </div>        <div class="form-group has-warning has-feedback">            <label>警告状态</label>            <input type="text" class="form-control" placeholder="警告状态">            <span class="glyphicon glyphicon-warning-sign form-control-feedback"></span>        </div></form>

效果如下:

 

表单提示信息

一般在制作表单验证时,需要提供不同的提示信息,在bootstrap框架中使用.help-block,将提示信息以块状显示,并且显示在控件底部

下面是css源码:

.help-block {display: block;margin-top: 5px;margin-bottom: 10px;color: #737373;}

例子:

<form>        <div class="form-group has-success has-feedback">            <label>成功状态</label>            <input type="text" class="form-control" placeholder="成功状态">            <span class="help-block">输入的信息正确</span>            <span class="glyphicon glyphicon-ok form-control-feedback"></span>        </div>        <div class="form-group has-error has-feedback">            <label>错误状态</label>            <input type="text" class="form-control" placeholder="错误状态">            <span class="help-block">输入的信息有误</span>            <span class="glyphicon glyphicon-remove form-control-feedback"></span>        </div>        <div class="form-group has-warning has-feedback">            <label>警告状态</label>            <input type="text" class="form-control" placeholder="警告状态">            <span class="help-block">请输入正确的信息</span>            <span class="glyphicon glyphicon-warning-sign form-control-feedback"></span>        </div> </form>

效果如下:

如果不想为bootstrap.css增加自己的代码,而且设计又有这种需要,可以借助bootstrap的网格系统,例如:

<form role="form">  <div class="form-group">    <label class="control-label" for="inputSuccess1">成功状态</label>    <div class="row">      <div class="col-xs-6">        <input type="text" class="form-control" id="inputSuccess1" placeholder="成功状态" >      </div>       <span class="col-xs-6 help-block">你输入的信息是正确的</span>    </div>  </div> </form>

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。