加入收藏 | 设为首页 | 会员中心 | 我要投稿 我爱故事小小网_铜陵站长网 (http://www.0562zz.com/)- 视频终端、云渲染、应用安全、数据安全、安全管理!
当前位置: 首页 > 服务器 > 搭建环境 > Windows > 正文

Bootstrap表单组件教程详解

发布时间:2016-11-25 02:38:47 所属栏目:Windows 来源:站长网
导读:表单常见的元素主要包括:文本输入框、下拉选择框、单选框、复选框、文本域、按钮等。下面是不同的bootstrap版本: LESS: forms.less SASS: _forms.scss bootstrap仅对表单内的fieldset、legend、label标签进行了定制 fieldset {min-width: 0;padding: 0;m

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

LESS: forms.less

SASS: _forms.scss

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

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等元素,在bootstrap框架中,通过定制一个类名.form-control来实现效果

1、宽度变成了100%;

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

3、具有4px的圆角

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

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

内联表单

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

lt;div class="form-group "gt;
lt;label class="sr-only"gt;邮箱地址lt;/labelgt;
lt;/divgt;
lt;div class="form-group"gt;
lt;input type="email" class="form-control" placeholder="请输入邮箱号"gt;
lt;/divgt;

效果如下:

nbsp;Bootstrap表单组件教程详解

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

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

例子:

lt;form class="form-inline"gt;
lt;div class="form-group"gt;
lt;label class="sr-only"gt;邮箱lt;/labelgt;
lt;input class="form-control" type="email" placeholder="请输入邮箱号"gt;
lt;/divgt;
lt;div class="form-group"gt;
lt;label class="sr-only"gt;密码lt;/labelgt;
lt;input type="password" class="form-control" placeholder="请输入密码"gt;
lt;/divgt;
lt;div class="checkbox"gt;
lt;labelgt;
lt;input type="checkbox" gt; 记住密码
lt;/labelgt;
lt;/divgt;
lt;div class="form-group"gt;
lt;button class="btn btn-default"gt;进入邮箱lt;/buttongt;
lt;/divgt;
lt;/formgt; 

效果如下:

nbsp;

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

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

既然添加了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源码:

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

例子:

lt;form class="form-horizontal"gt;
lt;div class="form-group"gt;
lt;label class="col-sm-2 control-label"gt;邮箱lt;/labelgt;
lt;div class="col-sm-10"gt;
lt;input type="email" class="form-control" placeholder="请输入邮箱"gt;
lt;/divgt;
lt;/divgt;
lt;div class="form-group"gt;
lt;label class="col-sm-2 control-label"gt;密码lt;/labelgt;
lt;div class="col-sm-10"gt;
lt;input type="password" class="form-control" placeholder="请输入密码"gt;
lt;/divgt;
lt;/divgt;
lt;div class="form-group"gt;
lt;div class="col-sm-10 col-sm-offset-2"gt;
lt;labelgt;
lt;input type="checkbox"gt;记住密码
lt;/labelgt;
lt;/divgt;
lt;/divgt;
lt;div class="form-group"gt;
lt;div class="col-sm-10 col-sm-offset-2"gt;
lt;button class="btn btn-default"gt;进入邮箱lt;/buttongt;
lt;/divgt;
lt;/divgt;
lt;/formgt; 

效果如下:

Bootstrap表单组件教程详解

单行输入框

(编辑:我爱故事小小网_铜陵站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读