专栏名称: OSC开源社区
OSChina 开源中国 官方微信账号
目录
相关文章推荐
程序员的那些事  ·  曾硬刚小米,估值 60 亿美元的独角兽被宣布破产! ·  3 天前  
程序员小灰  ·  男生看见雷军路过,直接冲过去递简历,结果... ·  2 天前  
OSC开源社区  ·  打磨了22年的重量级工业开源软件——Free ... ·  4 天前  
程序员小灰  ·  不愧是字节跳动,今年这薪资... ·  1 周前  
51好读  ›  专栏  ›  OSC开源社区

2017 年值得学习的 3 个 CSS 新特性

OSC开源社区  · 公众号  · 程序员  · 2017-03-11 08:30

正文

#点击图片,报名参加深圳源创会#


在众多的 CSS 新特性中,有 3 个今年采用的新特性让我抑制不住地激动。


1

特性查询


不久前,我写了我真心期望的一个 CSS 特性,就是关于特性查询,现在基本上可以说它已经存在了!它支持除 Internet Exploer 之外的主流浏览器(包括 Opera Mini)。

特性查询,使用 @supports 规则,允许我们将 CSS 包含在一个条件块中,这个条件块中会检查当前 user agent 是否支持一个 CSS 属性键值对,在支持的情况下其中的内容才会生效。这里有一个简单的例子,只在浏览器支持 Flexbox 的时候应用 display: flex - 

另外,使用像 and 和 not 这样的运算符,我们甚至可以创建更复杂的特性查询。比如,我们可以检测浏览器是否仅仅支持老的 Flexbox 语法 - 

支持情况


2

表格布局


CSS 表格布局模块所定义的系统用于创建基于表格的布局。它与弹性盒布局模块相似,但它更明确地为页面布局而设计,它们之间存在许多不同的特性。

明确项目定位

表格由表格容器(通过 display: grid 创建)和表格项(子组件)组成。在我们的 CSS 中,我们可以清楚的组织表格项的位置和顺序,而这与它们的标记(指 HTML 标记)无关。

例如,我写过一篇使用 CSS 表格进行圣怀布局,这篇文章中展示了通过这个模块如果创建有名的“圣杯布局”。

背后的 CSS 只有 31 行 -

灵活的长度

CSS Grid 模块引入了一个新的长度单位,fr,它代表了表格容器中剩余空间的一个等分。

它使得我们在表格容器根据可用空间来为表格项分配高度和宽度成为可能。例如在圣杯布局(Holy Grail Layout)中,我希望 main 分区占据两个边栏之外的所有空间。我写了一段简单的代码来做这个事情 -

间距

我们可以使用 grid-row-gap、grid-column-gap 和 grid-gap 属性来明确定义间距。这些属性的值是  数据类型,是内容区域尺寸的百分比。

比如,需要 %5 的间距,可以这样写 -

支持情况

CSS Grid 模块最早在今年三月被浏览器支持。


3

原生变量


最后要说的是原生 CSS 变量(级联变量模块的自定义属性)。这个模块引入了一种由创建作者定义变量的方法,这个变量可以像 CSS 属性一样赋值。

比如,假设在我们的样式表中多处用到一个主题颜色,我们可以将其抽象出来保存到变量中,再引用变量,以此代替多次直接写出实际的值。

目前在像 SASS 这样 CSS 预处理器中已经可以做到这些事情,但 CSS 变量在浏览器中具有活性。也就是说,它们的值可以实时更新。例如,要改变上例中 --theme-color 属性的值,我们只需要这样做 -

支持情况

支持情况如何

可以看到,目前没有一个特性被所有浏览器支持,那么我们应该怎样做才能高枕无忧地将其用于生产?答案是:渐进增强!去年我曾在前端开发大会(Fronteers Conference) 中谈到如何进行与 CSS 相关的渐进增强。现在我把它放在这里 -

2017 年你有兴趣学习什么样的 CSS 特性呢?




推荐阅读

3月19日深圳源创会报名正式启动!

TIOBE 3 月编程语言排行榜:Swift 首次进入前 10

5 个开源 Python 库,让机器学习更简单

10 个好用的 JavaScript 代码压缩工具

终于等到你,最强 IDE Visual Studio 2017 正式版发布

点击“阅读原文”查看更多精彩内容