Bootstrap4一次重大更新 几乎涉及每行代码


Posted in Javascript onMay 16, 2016

对Bootstrap来说去年8月19日是个特别的日子——不仅是项目四周年纪念日,也是经过了一年密集开发之后发布Bootstrap 4内测版的日子。Bootstrap 4是一次重大更新,几乎涉及每行代码。

1、新增功能

Bootstrap4一次重大更新 几乎涉及每行代码

Bootstrap 4中有太多重大的更新,本文不能面面俱到,下面是一些颇受关注的亮点:

从Less迁移到Sass: 现在,Bootstrap已加入Sass的大家庭中。得益于Libsass,Bootstrap的编译速度比以前更快;
改进网格系统:新增一个网格层适配移动设备,并整顿语义混合。
支持选择弹性盒模型(flexbox):这是项划时代的功能——只要修改一个Boolean变量,就可以利用flexbox的优势快速布局。
废弃了wells、thumbnails和panels,使用cards代替:Cards是个全新概念,但使用起来与wells、thumbnails及panels很像,且更方便。
将所有HTML重置样式表整合到Reboot中:在用不了Normalize.css的地方可以用Reboot了,它提供了更多选项。例如box-sizing: border-box、margin tweaks等都存放在一个单独的 Sass 文件中。
新的自定义选项:不再像上个版本一样,将渐变、淡入淡出、阴影等效果分放在单独的样式表中。而是将所有选项都移到一个Sass变量中。想要给全局或考虑不到的角落定义一个默认效果?很简单,只要更新变量值,然后重新编译就可以了。
不再支持IE8,使用rem和em单位:放弃对IE8的支持意味着开发者可以放心地利用CSS的优点,不必研究css hack技巧或回退机制了。使用rem和em代替px单位,更适合做响应式布局,控制组件大小。如果要支持IE8,只能继续用Bootstrap 3。
重写所有JavaScript插件:为了利用JavaScript的新特性,Bootstrap 4用ES6重写了所有插件。现在提供UMD支持、泛型拆解方法、选项类型检查等特性。
改进工具提示和popovers自动定位:这部分要感谢Tether工具的帮助。
改进文档:所有文档以Markdown格式重写,添加了一些方便的插件组织示例和代码片段,文档使用起来会更方便,搜索的优化工作也在进行中。
更多变化:支持自定义窗体控件、空白和填充类,此外还包括新的实用程序类等。
以上更新只是冰山一角, v4版共有1100多次commits和 12万行代码更新,这些更新可以在v4-alpha文档中查看。

2、开发计划

v4版本所有的源代码都在Github的v4-dev分支上开源。此外,还有一个v4开发和跟踪pr ,公布master的changes列表和待开发列表。大家可以贡献自己的代码,来让这个项目变得更好。

总体的开发和发布计划如下:

还会在不断改进中发布几个alpha版本; 新特性和新功能冻结之后发布两个Beta版本进行充分测试; 发布 2 个候选版本,测试是否能用于生产环境; 发布最终版本。

Slack上还有个专门讨论v4的频道,Bootstrapers可以点击这里加入。

3、支持v3

发布Bootstrap 3时,Bootstrap曾放弃了对2.x版本的支持,给很多用户造成了麻烦,同样的错误不会犯第二次。在不久的将来,开发团队还会继续修复v3的bug,改进文档。v4最终发布之后,v3的文档也不会下线。

4、One more thing……

除了发布Bootstrap 4 alpha外,官方还发布了Bootstrap主题。

Bootstrap4一次重大更新 几乎涉及每行代码这些主题耗费的精力很大,它们自己就有很多工具集,和Bootstrap本身一样。

作为开始,发布的主题有: dashboard, application,和marketing,使用multiple-use license 协议。

点击这里查看更多主题信息。

5、反馈

1)有人提到,在v3.5.5(最后的稳定版本)中,bootstrap.min.css是123KB,而在新的4.0.0alpha bootstrap.min.css 中只有88KB,值得庆祝。

2)有人反馈说dashboard主题并不是完完全全的响应式,比如在tables->order history中。

3)Bootstrap改成默认使用Sass,引起了广泛的讨论。

4)也有人表示,一个组织愿意放弃旧技术(不再支持IE8)用新技术(ES6)来重写库,值得尊敬。

如果大家还想深入学习,可以点击这里进行学习,再为大家附3个精彩的专题:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 读取XML数据,在页面中展现、编辑、保存的实现
Oct 27 Javascript
JQuery之拖拽插件实现代码
Apr 14 Javascript
javascript针对cookie的基本操作实例详解
Nov 30 Javascript
laypage分页控件使用实例详解
May 19 Javascript
jQuery插件zTree实现清空选中第一个节点所有子节点的方法
Mar 08 Javascript
Vue.extend构造器的详解
Jul 17 Javascript
vue自定v-model实现表单数据双向绑定问题
Sep 03 Javascript
利用jqgrid实现上移下移单元格功能
Nov 07 Javascript
jQuery实现的老虎机跑动效果示例
Dec 29 jQuery
vue自动路由-单页面项目(非build时构建)
Apr 30 Javascript
详解JavaScript之ES5的继承
Jul 08 Javascript
vue elementui tree 任意级别拖拽功能代码
Aug 31 Javascript
JS获取元素多层嵌套思路详解
May 16 #Javascript
怎么限制input的text里输入的值只能是数字(正则、js)
May 16 #Javascript
BootStrap点击下拉菜单项后显示一个新的输入框实现代码
May 16 #Javascript
在javascript中创建对象的各种模式解析
May 16 #Javascript
Bootstrap3 input输入框插入glyphicon图标的方法
May 16 #Javascript
论Bootstrap3和Foundation5网格系统的异同
May 16 #Javascript
Javascript基础教程之比较null和undefined值
May 16 #Javascript
You might like
PHP中如何调用webservice的实例参考
2013/04/25 PHP
基于PHP magic_quotes_gpc的使用方法详解
2013/06/24 PHP
memcache一致性hash的php实现方法
2015/03/05 PHP
PHP基于单例模式实现的mysql类
2016/01/09 PHP
php生成酷炫的四个字符验证码
2016/04/22 PHP
详谈PHP中的密码安全性Password Hashing
2017/02/04 PHP
PHP中PCRE正则解析代码详解
2019/04/26 PHP
让iframe自适应高度(支持XHTML,支持FF)
2007/07/24 Javascript
Ajax执行顺序流程及回调问题分析
2012/12/10 Javascript
js获取控件位置以及不同浏览器中的差别介绍
2013/08/08 Javascript
JS辨别访问浏览器判断是android还是ios系统
2014/08/19 Javascript
创建你的第一个AngularJS应用的方法
2015/06/16 Javascript
JS实现浏览器状态栏显示时间的方法
2015/10/27 Javascript
javascript实现2016新年版日历
2016/01/25 Javascript
浅谈jQuery双事件多重加载的问题
2016/10/05 Javascript
Nodejs下用submit提交表单提示cannot post错误的解决方法
2016/11/21 NodeJs
js通过classname来获取元素的方法
2016/11/24 Javascript
基于 Immutable.js 实现撤销重做功能的实例代码
2018/03/01 Javascript
jQuery 点击获取验证码按钮及倒计时功能
2018/09/20 jQuery
Jquery和CSS实现选择框重置按钮功能
2018/11/08 jQuery
js实现随机圆与矩形功能
2020/10/29 Javascript
[46:23]OG vs EG 2018国际邀请赛淘汰赛BO3 第一场 8.23
2018/08/24 DOTA
Python中的Matplotlib模块入门教程
2015/04/15 Python
Python简单实现自动删除目录下空文件夹的方法
2017/08/29 Python
用python结合jieba和wordcloud实现词云效果
2017/09/05 Python
python GUI实例学习
2017/11/21 Python
vscode 远程调试python的方法
2017/12/01 Python
Python设计模式之代理模式简单示例
2018/01/09 Python
在cmd中运行.py文件: python的操作步骤
2018/05/12 Python
Python qqbot 实现qq机器人的示例代码
2019/07/11 Python
什么是Rollback Segment
2013/04/22 面试题
自荐信怎么写好
2013/11/11 职场文书
企业活动策划方案
2014/06/02 职场文书
商家认证委托书格式
2014/10/16 职场文书
工作收入住址证明
2014/10/28 职场文书
Python实现仓库管理系统
2022/05/30 Python