声明: 本文已经首发于InfoQ中文站,版权所有,原文为《优秀的开源前端框架Bootstrap发布2.0.1版》,如需转载,请务必附带本声明,谢谢。

Bootstrap是著名的社交网站、微博的先驱Twitter在2011年8月推出的开源WEB前端框架,集合CSS和HTML,使用了最新的浏览器技术,为快速WEB开发提供了一套前端工具包,包括布局、网格、表格、按钮、表单、导航、提示等等。使用Bootstrap可以构建出非常优雅的前端界面,而且占用资源非常小。

Bootstrap发布时间不长,但是已经非常成熟了,目前最新版本是2.0,包括完整的CSS编译和非编译版本,样例模板和Javascript插件。

历史

早期Twitter的前端工程师几乎采用了任何自己熟悉的库来应对前端的开发需求,这样的造成的问题就是维护和扩展非常困难。最终Bootstrap成为应对这些挑战的解决方案,并开始在Twitter内部迅速成长,被twitter.com广泛采用,形成了稳定版本。随着工程师对其不断的开发和完善,Bootstrap进步显著,不仅包括基本样式,而且有了更为优雅和持久的前端设计模式。2011年8月,Twitter将其开源,相关地址:http://twitter.github.com/bootstrap

使用Bootstrap构建优雅的Web Page

Bootstrap的核心就是基于Less框架构建的CSS。所以谈到Bootstrap,就必须得说说Less。

关于Less

Less是一个动态CSS语言框架,Less扩展了CSS的动态特性,相对于传统的CSS,Less提供了更为强大的功能和灵活性。基于Less,我们可以在编写CSS时使用嵌入式申明、变量、混合模式、运算和颜色编辑功能函数等。简单来说就是Less可以让你像编程一样编写CSS,把程序存储在后缀为less的文件中,Less提供了框架将其编译为标准的css文件。举个简单的例子,如果你想为多个样式设置同一个颜色,可以这样写:

@color: #FFFFFF;
h1 {
color: @color;
}
#sub{
color: @color;
}

编译后的css就是:

h1 {color: #ffffff;
}
#sub {color: #ffffff;
}

以上代码只是Less的最简应用。除了变量,还可以在CSS进行数学运算、传参、文件相互引用、规则嵌套等等。可以想象,这种编写CSS的方式会为前端开发带来多大的改变。无论是从灵活性、扩展性和可维护性上,Less都让CSS开发有了大幅提升,动态性增强了。

Less的官方网站是http://lesscss.org/,很奇怪这样的网站会被我党封掉,需要FQ才能访问。

编译Less的方式很简单,有两种方式,一种是在使用时编译。下载less.js,在样式中引用:

<link rel="stylesheet/less" type="text/css" href="less/mystyles.less">

<script src="js/less.js" type="text/javascript"></script>

注意要把样式文件放到js文件申明的前面。

还有一种方式是使用前编译好,可以通过服务器端的Node.js进行编译,也可以到这个网站http://incident57.com/less/下载Less.app,提供了GUI方式编译less文件,目前只支持Mac OS X。

关于Less的使用,似乎需要写另一篇文章进行介绍,这里就不做更多的描述了。

基于Less编译的Bootstrap

使用了Less的Bootstrap具备如下优点:

1、Bootstrap实现起来依旧很简单,使用也很简单,把Bootstrap.css拖入你的代码即可。编译less文件可以使用less.js,Less.app或Node.js等多种方案实现。

2、一旦编译,Bootstrap框架仅包含CSS文件,这意味着没有多余的图片、Flash或Javascript,只有用于Web应用开发的简洁而强大的CSS样式。

兼容性

目前Bootstrap的最新版本是2.0,支持几乎所有的主流浏览器,包括Safari、Chrome,Firefox、IE7.0及以上,最新版本还支持智能手机WebUI。

2.0的新特性

Bootstrap的版本更新很快,2011年11月刚发布了1.4,2012年2月份就再次放出新版本2.0,而且有了大幅改进。

2.0版本采用了更灵活也更受欢迎的12栏网格布局,并以此来实现其各种布局框架。增加了响应式设计,以适应各种移动终端的需求。完善和改进原有样式库,并提供更丰富的新样式,包括样式繁多的图标(icon),漂亮易用的进度条等。改进和增加了自定义jQuery插件,完善文档,修复bug,同时还提供了很多基于Bootstrap构建的网站样例。

已经使用1.4的开发者也不用担心,Bootstrap专门提供了从1.4升级到2.0的手工向导可以参考。

功能集合

Bootstrap2.0把现有框架进行了清晰的功能划分,主要分为框架(Scaffolding),基础CSS,构件库和jQuery插件库。

Scaffolding主要提供基于网格的各种布局,包括普通网格系统、嵌入式网格,固定布局、自适应布局,同时可以对网格和布局进行自定义。Bootstrap2.0提供了响应式设计,可以通过单个文件支持各种手持设备,自适应不同的设备和屏幕变化。

基础CSS包括各种排版样式(标题、段落、引用块、列表、内联标签等),代码展示方面提供了基于code标签的内嵌代码,基于pre的块代码和基于Google Prettify的代码样式。同时提供各种表格、表单、按钮、图标的展示方式。

构件库提供了基于按钮、导航、标签、排版、警告、进度栏、图像网格等控件。

jQuery插件库则提供了十几种插件实现动态效果,例如Modal、Dropdown、Tab、Tooltip、Popover、Carousel等,开发者可以根据自己的业务需求使用不同的插件实现各种动态效果。

采用Bootstrap作为前端框架的网站示意图

更详细的信息请参考Bootstrap的官方网站。

Bootstrap——优秀的开源前端框架相关推荐

  1. 国内5款优秀的WEB前端框架

    1. JX(腾讯) 官网地址:http://alloyteam.github.io/JX/#home JX 是一个类似 Google Closure Library 的 Web 前端开发框架,服务于 ...

  2. 目前最流行的开源前端框架

    经常使用目前互联网比较流行的前端框架,小编根据自己工作中.关注中的一些前端框架进行了梳理,对于现在的开发者来说,都向着全栈方向发展,所以必须掌握些前端比较流行的框架,这样才能增强自己的技术体系框架,也 ...

  3. Framework7特色的HTML框架WebApp开源前端框架

    Framework7混合移动前端框架,轻量级.美观 中文官网地址: http://framework7.taobao.org/ 简单介绍: Framework7 是一个开源免费的框架可以用来开发混合移 ...

  4. 谷歌最新开源前端框架了解一下?前端小白都能看懂的8本书

    导读:跨平台.免费.开源,谷歌又搞"大新闻"?谷歌最新前端开发框架Flutter1.0版本已发布,可以极速构建漂亮的原生应用.各位前端大神都在用什么开发?下面八本书会帮助你快速入门 ...

  5. 【Java Web前端开发】前端框架 bootstrap+jquery+angularjs探索

    文章目录 1 Bootstrap 2 jQuery 3 AngularJS 1 Bootstrap 在Bootstrap的官网介绍中,Bootstrap is the most popular HTM ...

  6. 五款轻量级的web前端框架和H5前端框架

    目前主流的web前端框架有:Bootstrap.妹子UI.MUI移动前端框架等之外,国内的一些前端大神和前端大神团队琢磨出了以下几个不错的web前端框架. 第一款前端框架:FrozenUI – 专注于 ...

  7. webapp前端框架汇总

    转自:http://www.usheweb.com/a/daohang/2014/0827/902.html sencha touch 前不久基于JavaScript编写的Ajax框架ExtJS,将现 ...

  8. html5组件库,资源 | 10套好用的前端框架、设计组件库推荐

    No.1  Ant Design UI 框架 解析:蚂蚁金服出品,基于 ReactJS.一个服务于企业级产品的设计体系,支持桌面端.手机端.基于『确定』和『自然』的设计价值观,通过模块化的解决方案,让 ...

  9. 2018年五大最佳前端框架比较,程序员会怎么选?

    From: https://blog.csdn.net/qq_41852103/article/details/79619250 现在有大量的CSS前端框架可用.但真正好的屈指可数.本文将比较五个最佳 ...

最新文章

  1. 原理分析_变色近视眼镜原理分析
  2. python内置函数调用前_python之内置函数(一)
  3. ​​​​​​​​​​​​​​使用dom方式遍历文档||获取元素||从元素中获取数据
  4. mysql索引无效且sending data耗时巨大原因分析
  5. mysql TableMap id递增问题
  6. STL标准容器类简介
  7. Nc105-二分查找-II
  8. 2016福州大学软件工程第四次团队作业-系统设计成绩汇总
  9. 操作系统文件分配策略_操作系统中的文件分配方法
  10. [bzoj2648]SJY摆棋子(带插入kd-tree)
  11. ZeroMQ使用教程
  12. 灵活使用示波器触发功能,帮助大大提高测量效率
  13. SSE指令介绍及其C、C++应用 zz
  14. docker java镜像_Docker容器引擎与架构
  15. CNN训练Cifar-10技巧
  16. BootDo平台免密登陆
  17. Python爬取安居客租房数据,设置排除自己条件以外的数据
  18. ks检验正态分布结果_看SPSS如何检验数据是否服从正态分布
  19. 程序员走进偶像剧变身男主,网友:我服!
  20. 身份证、手机号、邮箱、银行卡、企业税号等正则校验

热门文章

  1. wordpress模版post.php,WordPress主题开发手册
  2. 利用 scipy.signal中的spectrogram分析信号的时频联合分布
  3. Grove Beginner Kits基础实验 Arduino
  4. 几款表贴LED反向电流特性
  5. python中scale的用法_Python Decimal scaleb()用法及代码示例
  6. Python结合mysql的实战_python连接mysql,实战。实现ATM类似功能。
  7. Linux卸载unity,你如何删除Unity?
  8. xilinx axi dma 深入开发(一)
  9. sqlite3 增删更改查询 callback使用
  10. ios微信登录不上服务器,iOS微信授权登录