前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2017年值得学习的3个CSS特性

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

作者头像
前端开发博客
发布2020-11-05 15:14:53
7200
发布2020-11-05 15:14:53
举报
文章被收录于专栏:前端开发博客前端开发博客

原文:https://bitsofco.de/3-new-css-features-to-learn-in-2017 译文:http://caibaojian.com/3-new-css-features-to-learn-in-2017.html 译者:前端开发博客(蔡宝坚)

未经许可,禁止转载,如有不妥之处,欢迎指正。

新年快乐! 随着新的一年到来,我们有一整套新的东西要开始学习。虽然今年的新特性有很多,但有3个新的特性是最令我激动不已的。

1.Feature Queries

前段时间,我写过关于Feature Queries的一篇文章,叫“我最想要的CSS特性之一”。好了,现在它已经出现在这里了。它支持除了IE浏览器之外的所有主流浏览器(包括Opera Mini)。

Feature Queries,使用这个 @supports 规则,允许我们包含CSS在一个条件块,但只有当前用户客户端支持一个特别的CSS property-value 才有效。举个简单的例子,只支持 display:flex 的浏览器才用Flexbox样式。

代码语言:javascript
复制
@supports ( display:flxe ){    
.foo { display:flex; }
}

另外,使用像 andnot 的操作符,我们可以创建更加复杂的特性查询。例如,我们可以检测一个浏览器只支持旧的Flexbox语法-

代码语言:javascript
复制
@supports ( display: flexbox )
         and
         ( not ( display: flex ) ) {  
.foo { display: flexbox; }
}

兼容情况

2.Grid 布局

CSS 网格布局模块定义了一个以创建网格为基础的布局系统。它跟Flexbible Box 布局模块很相似,但它更多的是为页面布局而设计,因此具有许多不同的特性。

清晰的项放置

一个网格是由Grid Container(用 display: grid 创建),和Grid项(这是子项)构成。在我们的CSS中,我们可以容易并且清晰的组织网格项的放置和顺序,而不用管他们在标记中的放置。

举个例子,在我的文章“使用CSS网格的圣杯布局,我展示一下我们如何使用这个组件来创建类似的“圣杯布局”。

下面这个CSS只有短短31行

代码语言:javascript
复制
.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 容器占据除了两个侧栏之外剩下的空间,为了实现这个,我简单的写了:

代码语言:javascript
复制
.hg {    
grid-template-columns: 150px 1fr 150px;
}

间距

我们可以使用 grid-row-gap, grid-column-gapgrid-gap属性为我们的网格布局具体定义间隔。这些属性接受一个length-percentage 数据类型作为值,百分比对应于内容的区域。

举个例子,有一个5%的间隙,我们可以这样子写:

代码语言:javascript
复制
.hg {    
display: grid;    
grid-column-gap: 5%;
}

兼容情况

CSS网格组件最早在今年3月份将可以使用在浏览器中

3.原生变量

最近,原生CSS变量(css变量组件自定义属性)。这个组件介绍一个创建自定义变量的方法,它可以赋值给CSS属性。

举个例子,如果我们需要在样式表中多个地方使用到colour,我们可以把它当做一个变量和并引用它,而不必多次写它的实际值。

代码语言:javascript
复制
:root { 
 --theme-colour: cornflowerblue;
}
h1 { 
color: var(--theme-colour); 
}  
a { color: var(--theme-colour); }  
strong { color: var(--theme-colour); }

现在有很多CSS预处理器像SASS可以做到这一点,但CSS变量有浏览器支持的优势。这意味着它们的值可以实时更新。为了改变下面的属性 --theme-colour ,例如,我们需要做的就是下面这个了:

代码语言:javascript
复制
const rootEl = document.documentElement;  
rootEl.style.setProperty('--theme-colour', 'plum');

兼容情况

什么是兼容情况

如你所见,不是所有的特性都被所有浏览器所支持,所以我们要如何合适使用它们在生产中?好吧,用渐进增强!上一年,我在Fronteers 会议上讲了一个关于如何在CSS上使用渐进增加的演讲。你可以看一下下面这个: https://player.vimeo.com/video/194815985

欢迎关注“前端开发博客”微信,每周不定期推送优秀的文章。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2017-06-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端开发博客 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.Feature Queries
    • 兼容情况
    • 2.Grid 布局
      • 清晰的项放置
        • 灵活的长度
          • 间距
            • 兼容情况
            • 3.原生变量
              • 兼容情况
              • 什么是兼容情况
              相关产品与服务
              容器服务
              腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档