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中实现暂停的几篇文章
Mar 04 Javascript
Document:getElementsByName()使用方法及示例
Oct 28 Javascript
javascript中异常处理案例(推荐)
Oct 03 Javascript
详解微信小程序开发之城市选择器 城市切换
Jan 17 Javascript
Angular模板表单校验方法详解
Aug 11 Javascript
浅析Vue中method与computed的区别
Mar 06 Javascript
基于JavaScript实现瀑布流布局
Aug 15 Javascript
layui实现文件或图片上传记录
Aug 28 Javascript
简化版的vue-router实现思路详解
Oct 19 Javascript
详解如何用typescript开发koa2的二三事
Nov 13 Javascript
js实现html滑动图片拼图验证
Jun 24 Javascript
vue 在单页面应用里使用二级套嵌路由
Dec 19 Vue.js
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
漫荒推荐:画风超赞的国风漫画推荐 超长假期不无聊
2020/03/08 国漫
第十三节 对象串行化 [13]
2006/10/09 PHP
推荐文章系统(一)
2006/10/09 PHP
我的论坛源代码(八)
2006/10/09 PHP
PHP中fwrite与file_put_contents性能测试代码
2013/08/02 PHP
PHP验证类的封装与使用方法详解
2019/01/10 PHP
javascript json 新手入门文档
2009/12/03 Javascript
javascript将数组插入到另一个数组中的代码
2013/01/10 Javascript
JQUERY对单选框(radio)操作的小例子
2013/04/25 Javascript
通过js简单实现将一个文本内容转译成加密文本
2013/10/22 Javascript
setTimeout()与setInterval()方法区别介绍
2013/12/24 Javascript
jquery获得keycode的示例代码
2013/12/30 Javascript
javascript中的事件代理初探
2014/03/08 Javascript
document.compatMode的CSS1compat使用介绍
2014/04/03 Javascript
jquery复选框checkbox实现删除前判断
2014/04/20 Javascript
JS实现网页表格自动变大缩小的方法
2015/03/09 Javascript
JavaScript实现学生在线做题计时器功能
2018/12/05 Javascript
OpenLayers加载缩放控件使用方法详解
2020/09/25 Javascript
浅谈python类属性的访问、设置和删除方法
2016/07/25 Python
pyqt5简介及安装方法介绍
2018/01/31 Python
Django restframework 源码分析之认证详解
2019/02/22 Python
django celery redis使用具体实践
2019/04/08 Python
Python3显示当前时间、计算时间差及时间加减法示例代码
2019/09/07 Python
python中web框架的自定义创建
2019/09/08 Python
详解pandas中利用DataFrame对象的.loc[]、.iloc[]方法抽取数据
2020/12/13 Python
Gina Bacconi官网:吉娜贝康尼连衣裙和礼服
2018/04/24 全球购物
英国女性时尚鞋类的潮流制造者:Koi Footwear
2018/10/19 全球购物
SmartBuyGlasses比利时:购买品牌太阳镜和眼镜
2019/08/09 全球购物
C#可否对内存进行直接的操作
2015/02/26 面试题
应届生财务会计求职信
2013/11/05 职场文书
《桃林那间小木屋》教学反思
2014/05/01 职场文书
运动会加油稿100字
2014/09/19 职场文书
财务审计整改报告
2014/11/06 职场文书
运动会通讯稿600字
2015/07/20 职场文书
oracle通过存储过程上传list保存功能
2021/05/12 Oracle
修改并编译golang源码的操作步骤
2021/07/25 Golang