Bootstrap表单组件教程详解

前端之家收集整理的这篇文章主要介绍了Bootstrap表单组件教程详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

表单常见的元素主要包括:文本输入框、下拉选择框、单选框、复选框、文本域、按钮等。下面是不同的bootstrap版本:

LESS: forms.less

SASS: _forms.scss

bootstrap仅对表单内的fieldset、legend、label标签进行了定制

除了这个几个元素之外,还有input、select、textarea等元素,在bootstrap框架中,通过定制一个类名.form-control来实现效果

1、宽度变成了100%;

2、设置了一个浅灰色(#ccc)的边框

3、具有4px的圆角

4、设置阴影效果,并且元素得到焦点时,阴影和边框效果会有所变化

5、设置了palceholder的颜色为#999

内联表单

如果要在input之前添加一个了label标签,会导致input换行显示;如果又必须添加这样一个label标签,且不想让input换行,就需要将label标签也放在容器.form-group中,例如:

效果如下:

实现联表单效果只需在form元素中添加类名.form-inline即可,实现原理:

将表单控件设置成内联块元素(display:inline-block),让表单控件在一行显示

例子:

Box">

效果如下:

看到上图效果你有没有发现代码里明明有label标签,且没放在容器.form-group中,input也不会换行,更奇怪的是label标签内容居然没有显示出来!其实仔细一看label标签添加了类名.sr-only,就是它将label给隐藏起来了,来看看它的源码:

既然添加了label标签,又添加.sr-only类名把label给隐藏起来,是不是多此一举???但这恰恰是bootstrap框架的一个优点,如果没有为输入控件设置label,屏幕阅读器将无法正确识别,同时也为残障人员进行了一定的考虑

水平表单

在bootstrap中实现水平表单效果需满足下面两个条件:

1、在form元素上使用类名.form-horizontal

2、配合bootstrap框架的网格系统(详细:详解Bootstrap网格系统)

在form元素使用类名.form-horizontal主要有以下几个作用:

1、设置表单控件padding和margin值

2、改变.from-group的表现形式,类似于网格系统的row

css源码:

dio,.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; }

例子:

Box">记住密码

效果如下:

单行输入框

在bootstrap中使用input时也必须添加type类型,如果没有指定type类型,将无法得到正确的样式,因为bootstrap框架都是通过input[type=”?”]的形式来定义样式的,如:text类型,对应得是input[type=”text”]

为了让控件在各种表单风格中样式不错,需要添加类名.form-control

下拉选择框select

多行选择设置multiple属性的值为multiple

1
1

文本域textarea

文本域和原始使用方法一样,设置rows可定义其高度,设置cols可以定义其宽度,如果textarea元素中添加了类名.form-control,则无需设置cols属性,因为bootstrap框架中.form-control样式的标的空间宽度为100%或auto

复选框checkBox和单选框radio

checkBox和radio与label标签配合使用会出现一些小问题(如对齐问题)

Box">
dio">
dio">

1、不管是checkBox还是radio都使用label包起来了

2、checkBox连同label标签放在一个名为.checkBox的容器内

3、radio连同label标签放在一个名为.radio的容器内,bootstrap主要借助.checkBox和.radio样式来处理复选框、单选按钮与标签的对齐方式

dio,.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; }

复选框和单选按钮水平排列

1、如果checkBox需要水平排列,只需要在label标签添加类名.checkBox-inline

2、如果radio需要水平排列,只需在label标签添加类名.radion-inline

下面是css源码:

dio-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; }
dio-inline"> dio" name="sex"value="option1"> 男性

表单控件状态

1、焦点状态:

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

css源码:

Box-shadow: inset 0 1px 1pxrgba(0,.075),0 0 8px rgba(102,175,233,.6); Box-shadow: inset 0 1px 1pxrgba(0,.6); }

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

效果">
效果">

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

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

2、禁用状态:

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

dio"][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; }

例子:

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

例子:

输入框已禁用 禁止输入内容">
下拉框已禁用
Box">

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

3、验证状态

bootstrap提供下面这几种效果

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

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

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

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

例子:

成功状态
错误状态 错误状态">
警告状态

效果如下:

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

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

例子:

Feedback"> Feedback">
Feedback"> 错误状态"> Feedback">
Feedback"> Feedback">

效果如下:

表单提示信息

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

下面是css源码:

例子:

Feedback"> Feedback">
Feedback"> 错误状态"> Feedback">
Feedback"> Feedback">

效果如下:

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

以上所述是小编给大家介绍的Bootstrap表单组件的相关内容,希望对大家有所帮助!

bootstrap组件bootstrap表单组件

猜你在找的Bootstrap相关文章