Bootstrap3.0学习第六轮(表单)

前言

阅读之前您也可以到Bootstrap3.0入门学习系列导航中进行查看http://www.cnblogs.com/aehyok/p/3404867.html

本文主要讲解的是表单,这个其实对于做过网站的人来说,并不陌生,而且可以说是最为常用的提交数据的Form表单。本文主要来讲解一下内容:

1.基本案例

2.内联表单

3.水平排列的表单

4.被支持的控件

5.静态控件

6.控件状态

7.控件尺寸

8.帮助文本

9.总结

基本案例

单独的表单控件会被自动赋予一些全局样式。所有设置了.form-control<input><textarea><select>元素都将被默认设置为width: 100%;。将label和前面提到的这些控件包裹在.form-group中可以获得最好的排列。

  1. <form role="form">
  2. <div class="form-group">
  3. <label for="exampleInputEmail1">Email address</label>
  4. <input type="email" class="form-control" id="exampleInputEmail1" placeholder="Enter email">
  5. </div>
  6. <div class="form-group">
  7. <label for="exampleInputPassword1">Password</label>
  8. <input type="password" class="form-control" id="exampleInputPassword1" placeholder="Password">
  9. </div>
  10. <div class="form-group">
  11. <label for="exampleInputFile">File input</label>
  12. <input type="file" id="exampleInputFile">
  13. <p class="help-block">Example block-level help text here.</p>
  14. </div>
  15. <div class="checkbox">
  16. <label>
  17. <input type="checkbox"> Check me out
  18. </label>
  19. </div>
  20. <button type="submit" class="btn btn-default">Submit</button>
  21. </form>

两个文本框的宽度的确为100%。并且有三个form-group。

内联表单

为左对齐和inline-block级别的控件设置.form-inline,可以将其排布的更紧凑。

需要设置宽度:在Bootstrap中,input、select和textarea默认被设置为100%宽度。为了使用内联表单,你需要专门为使用到的表单控件设置宽度。

一定要设置label:如果你没有为每个输入控件设置label,屏幕阅读器将无法正确识读。对于这些内联表单,你可以通过为label设置.sr-only已将其隐藏。

  1. <form class="form-inline" role="form">
  2. <div class="form-group">
  3. <label class="sr-only" for="exampleInputEmail2">Email address</label>
  4. <input type="email" class="form-control" id="exampleInputEmail2" placeholder="Enter email">
  5. </div>
  6. <div class="form-group">
  7. <label class="sr-only" for="exampleInputPassword2">Password</label>
  8. <input type="password" class="form-control" id="exampleInputPassword2" placeholder="Password">
  9. </div>
  10. <div class="checkbox">
  11. <label>
  12. <input type="checkbox"> Remember me
  13. </label>
  14. </div>
  15. <button type="submit" class="btn btn-default">Sign in</button>
  16. </form>

水平排列的表单

通过为表单添加.form-horizontal,并使用Bootstrap预置的栅格class可以将label和控件组水平并排布局。这样做将改变.form-group的行为,使其表现为栅格系统中的行(row),因此就无需再使用.row了。

  1. <form class="form-horizontal" role="form">
  2. <div class="form-group">
  3. <label for="inputEmail3" class="col-sm-2 control-label">Email</label>
  4. <div class="col-sm-10">
  5. <input type="email" class="form-control" id="inputEmail3" placeholder="Email">
  6. </div>
  7. </div>
  8. <div class="form-group">
  9. <label for="inputPassword3" class="col-sm-2 control-label">Password</label>
  10. <div class="col-sm-10">
  11. <input type="password" class="form-control" id="inputPassword3" placeholder="Password">
  12. </div>
  13. </div>
  14. <div class="form-group">
  15. <div class="col-sm-offset-2 col-sm-10">
  16. <div class="checkbox">
  17. <label>
  18. <input type="checkbox"> Remember me
  19. </label>
  20. </div>
  21. </div>
  22. </div>
  23. <div class="form-group">
  24. <div class="col-sm-offset-2 col-sm-10">
  25. <button type="submit" class="btn btn-default">Sign in</button>
  26. </div>
  27. </div>
  28. </form>

被支持的控件

在表单布局案例中展示了其所支持的标准表单控件。

Input

大部分表单控件、文本输入域控件。包括HTML5支持的所有类型:textpassworddatetimedatetime-localdatemonthtimeweeknumberemailurlsearchtelcolor

注意:有正确设置了type的input控件才能被赋予正确的样式。

文本框示例

  1. <input type="text" class="form-control" placeholder="Text input">

Textarea

支持多行文本的表单控件。可根据需要改变rows属性。

  1. <h1>textarea</h1>
  2. <textarea class="form-control" rows="3"></textarea>

Checkbox 和 radio

Checkbox用于选择列表中的一个或多个选项,而radio用于从多个选项中只选择一个。

默认外观(堆叠在一起)

  1. <div class="checkbox">
  2. <label>
  3. <input type="checkbox" value="">
  4. Option one is this and that&mdash;be sure to include why it's great
  5. </label>
  6. </div>
  7.  
  8. <div class="radio">
  9. <label>
  10. <input type="radio" name="optionsRadios" id="optionsRadios1" value="option1" checked>
  11. Option one is this and that&mdash;be sure to include why it's great
  12. </label>
  13. </div>
  14. <div class="radio">
  15. <label>
  16. <input type="radio" name="optionsRadios" id="optionsRadios2" value="option2">
  17. Option two can be something else and selecting it will deselect option one
  18. </label>
  19. </div>

Inline checkboxes

通过将.checkbox-inline 或 .radio-inline应用到一系列的checkbox或radio控件上,可以使这些控件排列在一行。

  1. <label class="checkbox-inline">
  2. <input type="checkbox" id="inlineCheckbox1" value="option1"> 1
  3. </label>
  4. <label class="checkbox-inline">
  5. <input type="checkbox" id="inlineCheckbox2" value="option2"> 2
  6. </label>
  7. <label class="checkbox-inline">
  8. <input type="checkbox" id="inlineCheckbox3" value="option3"> 3
  9. </label>

同理Radio是一样的,只需要添加一下样式即可。

Select

  1. <select class="form-control">
  2. <option>1</option>
  3. <option>2</option>
  4. <option>3</option>
  5. <option>4</option>
  6. <option>5</option>
  7. </select>
  8.  
  9. <select multiple class="form-control">
  10. <option>1</option>
  11. <option>2</option>
  12. <option>3</option>
  13. <option>4</option>
  14. <option>5</option>
  15. </select>

静态控件

在水平布局的表单中,如果需要将一行纯文本放置于label的同一行,为<p>元素添加.form-control-static即可。

  1. <form class="form-horizontal" role="form">
  2. <div class="form-group">
  3. <label class="col-sm-2 control-label">Email</label>
  4. <div class="col-sm-10">
  5. <p class="form-control-static">email@example.com</p>
  6. </div>
  7. </div>
  8. <div class="form-group">
  9. <label for="inputPassword" class="col-sm-2 control-label">Password</label>
  10. <div class="col-sm-10">
  11. <input type="password" class="form-control" id="inputPassword" placeholder="Password">
  12. </div>
  13. </div>
  14. </form>

控件状态

控件状态

  通过为控件和label设置一些基本状态,可以为用户提供回馈。

  输入焦点

  我们移除了某些表单控件的默认outline样式,并对其:focus状态赋予了box-shadow样式。

  1. <input class="form-control" id="focusedInput" type="text" value="This is focused...">

  被禁用的输入框

  为输入框设置disabled属性可以防止用户输入,并能改变一点外观,使其更直观。

  1. <input class="form-control" id="disabledInput" type="text" placeholder="Disabled input here..." disabled>

  被禁用的fieldset

  为<fieldset>设置disabled属性可以禁用<fieldset>中包含的所有控件。

<a>标签的链接功能不受影响

这个class只改变<a class="btn btn-default">按钮的外观,并不能禁用其功能。建议自己通过JavaScript代码禁用链接功能。

跨浏览器兼容性

虽然Bootstrap会将这些样式应用到所有浏览器上,Internet Explorer 9及以下浏览器中的<fieldset>并不支持disabled属性。因此建议在这些浏览器上通过JavaScript代码来禁用fieldset

  1. <form role="form">
  2. <fieldset disabled>
  3. <div class="form-group">
  4. <label for="disabledTextInput">Disabled input</label>
  5. <input type="text" id="disabledTextInput" class="form-control" placeholder="Disabled input">
  6. </div>
  7. <div class="form-group">
  8. <label for="disabledSelect">Disabled select menu</label>
  9. <select id="disabledSelect" class="form-control">
  10. <option>Disabled select</option>
  11. </select>
  12. </div>
  13. <div class="checkbox">
  14. <label>
  15. <input type="checkbox"> Can't check this
  16. </label>
  17. </div>
  18. <button type="submit" class="btn btn-primary">Submit</button>
  19. </fieldset>
  20. </form>

  可将鼠标移到各个控件上进行查看效果。

校验状态

Bootstrap对表单控件的校验状态,如error、warning和success状态,都定义了样式。使用时,添加.has-warning.has-error.has-success到这些控件的父元素即可。任何包含在此元素之内的.control-label.form-control.help-block都将接受这些校验状态的样式。

  1. <div class="form-group has-success">
  2. <label class="control-label" for="inputSuccess">Input with success</label>
  3. <input type="text" class="form-control" id="inputSuccess">
  4. </div>
  5. <div class="form-group has-warning">
  6. <label class="control-label" for="inputWarning">Input with warning</label>
  7. <input type="text" class="form-control" id="inputWarning">
  8. </div>
  9. <div class="form-group has-error">
  10. <label class="control-label" for="inputError">Input with error</label>
  11. <input type="text" class="form-control" id="inputError">
  12. </div>

控件尺寸

通过.input-lg之类的class可以为控件设置高度,通过.col-lg-*之类的class可以为控件设置宽度。

高度尺寸

创建大一些或小一些的表单控件以匹配按钮尺寸。

  1. <input class="form-control input-lg" type="text" placeholder=".input-lg">
  2. <input class="form-control" type="text" placeholder="Default input">
  3. <input class="form-control input-sm" type="text" placeholder=".input-sm">
  4.  
  5. <select class="form-control input-lg">...</select>
  6. <select class="form-control">...</select>
  7. <select class="form-control input-sm">...</select>

调整列尺寸

用栅格系统中的列包裹input或其任何父元素,都可很容易的为其设置宽度。

  1. <div class="row">
  2. <div class="col-xs-2">
  3. <input type="text" class="form-control" placeholder=".col-xs-2">
  4. </div>
  5. <div class="col-xs-3">
  6. <input type="text" class="form-control" placeholder=".col-xs-3">
  7. </div>
  8. <div class="col-xs-4">
  9. <input type="text" class="form-control" placeholder=".col-xs-4">
  10. </div>
  11. </div>

帮助文本

用于表单控件的块级帮助文本。

  1. <span class="help-block">自己独占一行或多行的块级帮助文本。</span>

总结

本篇文章主要讲解表单中各种控件的样式控制。其中也有看到按钮的简单样式使用,下一篇文章将重点来讲解按钮的样式。

本文已更新至Bootstrap3.0入门学习系列导航中http://www.cnblogs.com/aehyok/p/3404867.html

 
 

Bootstrap3.0学习第六轮(表单)的更多相关文章

  1. Bootstrap3.0学习第二十一轮(JavaScript插件——工具提示)

    详情请查看http://aehyok.com/Blog/Detail/27.html 个人网站地址:aehyok.com QQ 技术群号:206058845,验证码为:aehyok 本文文章链接:ht ...

  2. Bootstrap3.0学习第十七轮(JavaScript插件——模态框)

    详情请查看http://aehyok.com/Blog/Detail/24.html 个人网站地址:aehyok.com QQ 技术群号:206058845,验证码为:aehyok 本文文章链接:ht ...

  3. Bootstrap3.0学习第十一轮(输入框组)

    详情请查看http://aehyok.com/Blog/Detail/17.html 个人网站地址:aehyok.com QQ 技术群号:206058845,验证码为:aehyok 本文文章链接:ht ...

  4. Bootstrap3.0学习第七轮(按钮)

    详情请查看http://aehyok.com/Blog/Detail/13.html 个人网站地址:aehyok.com QQ 技术群号:206058845,验证码为:aehyok 本文文章链接:ht ...

  5. bootstrap学习笔记<六>(表单二之按钮)

    按钮(补充) (ps:居中元素可以使用<center></center>标签) 块级按钮(ps:按钮占一整行) <button class="btn btn-p ...

  6. Laravel教程 六:表单 Forms

    Laravel教程 六:表单 Forms 此文章为原创文章,未经同意,禁止转载. Form laravel 5.2 之后请使用 laravelcollective/html 替换 illuminate ...

  7. Bootstrap3.0学习第三轮(栅格系统案例)

    Bootstrap3.0学习第三轮(栅格系统案例) 前言 在前面的一篇文章当中http://www.cnblogs.com/aehyok/p/3400499.html主要学习了栅格系统的基本原理,以及 ...

  8. struts2官方 中文教程 系列六:表单验证

    先贴个本帖的地址,以免被爬:struts2教程 官方系列六:表单验证  即 http://www.cnblogs.com/linghaoxinpian/p/6906720.html 下载本章节代码 介 ...

  9. Ext JS4 学习笔记之发送表单(Form)时也将表单下的表格(Grid)数据一同发送的方法

    Ext JS4 学习笔记之发送表单(Form)时也将表单下的表格(Grid)数据一同发送的方法 昨天在开发的时候遇到个小问题,就是如何将Grid的内容与Form一起发送到服务器端.默认情况下,表单(F ...

随机推荐

  1. jdk1.7 变更

    个人实遇: 1.6与1.7 :SimpleDateFormat,1.6要求yyyy必须小写,1.7兼容大小写: jdk 8 新特性: 官方pdf文档(英文版)私人下载地址:http://pan.bai ...

  2. VisualStudio 自动排版等 快捷键

    VisualStudio2010自动排版快捷键:全部代码排版:1. ctrl+E,D 按住ctrl,相继按下E.D                          2. ctrl+K,F 按住ctr ...

  3. Hibernate_10_继承的例子_单表

     只是建一个表,所有属性都包括在此表.使用discriminator 到父和子类之间的区别. 1)父类(Article): public class Article { private Integer ...

  4. utf8 和 UTF-8 在使用中的差别

    在使用中经常遇到utf-8和utf8,如今最终弄明确他们的使用不同之处了,如今来和大家分享一下,以下我们看一下utf8 和 UTF-8 有什么差别  "UTF-8"是标准写法,ph ...

  5. 项目开发经常使用PHP功能

    日期操作 为了便于存储.比较和交付.我们通常使用strtotime()功能转换的日期UNIX时间戳.有仅用于在显示给用户时date()成经常使用的时间格式. strtotime()  函数将不论什么英 ...

  6. 跟着大神重写的KNN 文档归类小工具

    ·背景 在知道KNN之前,楼主有时候会粗糙地做一些分类模型的计算.在拜读了Orisun大神[http://www.cnblogs.com/zhangchaoyang/articles/2162393. ...

  7. java设计模式之六适配器模式(Adapter)

    适配器模式将某个类的接口转换成客户端期望的另一个接口表示,目的是消除由于接口不匹配所造成的类的兼容性问题.主要分为三类:类的适配器模式.对象的适配器模式.接口的适配器模式.首先,我们来看看类的适配器模 ...

  8. 于CentOS 6 安装 Wordpress

    1.两种方式给Wordpress 首先,你可以去wordpress最新的官方网站看看wordpress多少下载.例wordpress 3.9.1下载地址: http://cn.wordpress.or ...

  9. EasyMonkeyDevice vs MonkeyDevice&HierarchyViewer API Mapping Matrix

    1. 前言 本来这次文章的title是写成和前几篇类似的<EasyMonkeyDevice API实践全记录>,内容也打算把每个API的实践和建议给记录下来,但后来想了下觉得这样子并不是最 ...

  10. Python 图论工具

    networkx: 一个用Python语言开发的图论与复杂网络建模工具, 内置了经常使用的图与复杂网络分析算法, 能够方便的进行复杂网络数据分析.仿真建模等工作. 依赖工具: numpy  pypar ...