2017年要学习的3个CSS新特性

本文转载自:众成翻译
译者:dainiel
链接:http://www.zcfy.cc/article/2360
原文:https://bitsofco.de/3-new-css-features-to-learn-in-2017/

新年快乐! 🎊

随着新一年的到来,我们可以学习的干活又多了好多。新特性虽然有很多,但有三个是今年最让我激动不已的。

1. Feature Queries

译者注:因为media query一样,大家习惯不翻译,所以这里也不直译为:特性查询

之前我写过了一篇关于Feature Queries的文章《我真正想要的CSS特性》。好吧,现在它已经来了!(包括Opera Mini在内的)所有主流浏览器,除了IE,都已经支持这个特性了。

Feature Queries,使用@supports规则,可以让大家在把CSS写在特定的代码块中,但是只有在当前用户代理支持特定的CSS键值对时其才会生效。这里有个简单的例子,对于支持display: flex的浏览器,下面的Flexbox的样式才会生效:

@supports ( display: flex ) {
  .foo { display: flex; }
}

此外,使用像andnot的操作符,我们可以创造出更为复杂的feature queries。例如,我们可以检测出浏览器是否只支持旧的Flexbox语法:

@supports ( display: flexbox ) 
          and 
          ( not ( display: flex ) ) {
  .foo { display: flexbox; }
}

支持情况

[

Data on support for the css-feature queries feature
](http://caniuse.com/#feat=css-featurequeries

2. 网格布局

CSS网格布局模块定义了一个用来创造基于网格的布局系统。它和弹性盒子布局模块相似,但其是专门为页面布局设计的,所以也会有许多不同的特性。

清晰的子项布置

网格是由网格容器(通过display: grid构建)和网格子项(其为网格的子元素)组成。在我们的CSS里,我们可以简单明了的组织网格子项的位置和次序,而不受其在代码中位置的影响。

例如,在我的文章 《使用CSS网格的圣杯布局》中,我演示了我们可以怎么使用这个模块来书写出臭名昭著的“圣杯布局”。

Holy Grail Layout Demo

下面的CSS只有31行:

.hg__header { grid-area: header; }
.hg__footer { grid-area: footer; }
.hg__main { grid-area: main; }
.hg__left { grid-area: navigation; }
.hg__right { grid-area: ads; }

.hg {
    display: grid;
    grid-template-areas: "header header header"
                         "navigation main ads"
                         "footer footer footer";
    grid-template-columns: 150px 1fr 150px;
    grid-template-rows: 100px 
                        1fr
                        30px;
    min-height: 100vh;
}

@media screen and (max-width: 600px) {
    .hg {
        grid-template-areas: "header"
                             "navigation"
                             "main"
                             "ads"
                             "footer";
        grid-template-columns: 100%;
        grid-template-rows: 100px 
                            50px 
                            1fr
                            50px 
                            30px;
    }
}

灵活的长度

CSS网格模块引入了一个新的长度单位fr,其表示在网格容器里剩余空间的部分。

这就可以让我们根据网格容器的可用空间来分配网格子项的宽高。例如,在圣杯布局中,我想让 main区域占据除两个边栏外的空间。为了实现这个,我简单地写了:

.hg {
    grid-template-columns: 150px 1fr 150px;
}

间隔

我们使用grid-row-gapgrid-column-gap, 和 grid-gap 属性可以去具体地定义间隔。这些属性接受`` data type作为值,其比例与内容区域的尺寸一致。

例如,为了有5%的间隔,你可以这样写:

.hg {
    display: grid;
    grid-column-gap: 5%;
}

支持情况

CSS网格模块最早今年三月会在浏览器上可用。

3. 原生变量

终于等到你,CSS本地变量(Custom Properties for Cascading Variables Module)。此模块引入了一个方法,可以用其创造作为CSS属性值的自定义变量。

例如,如果我们有一个在样式表里多处使用的主题颜色,我们可以把其提取出来放入一个变量中,同时引用此变量,而不是把实际值去写好多遍。

:root {
  --theme-colour: cornflowerblue;
}

h1 { color: var(--theme-colour); }  
a { color: var(--theme-colour); }  
strong { color: var(--theme-colour); }

这和我们之前用像SASS这样的CSS预处理器很像,但是CSS变量有浏览器原生支持的优势。这也就意味着其可以实时更新。例如,为了改变上面的--theme-colour值,我们需要做的是:

const rootEl = document.documentElement;  
rootEl.style.setProperty('--theme-colour', 'plum');

支持情况

支持情况怎么样呢?

正如你所见,目前这些功能并没有在所有浏览器上获得充分支持,那么我们怎么在产品中使用才合适呢?额,当然是渐进增强!去年我就在前端大会上发表了关于怎么把渐进增强运用到CSS中的演讲。你可以在下面看到当时的演讲:

2017又有什么CSS特性是会让你激动不已的呢?

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容