博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2017年要学习的三个CSS新特性
阅读量:7249 次
发布时间:2019-06-29

本文共 2677 字,大约阅读时间需要 8 分钟。

新的一年,我们有一系列新的东西要学习。尽管CSS有很多新的特性,但有三个特性令我最激动并进行学习。

1. Feature Queries(特性查询)

在这之前我写了一篇关于Feature Queries的文章。现在,它已经在这里了!目前所有主流浏览器都支持特征查询(包括Opera Mini),IE浏览器除外。

,使用@supports规则,允许我们在它的条件区域内写入CSS规则,只有当当前的用户浏览器支持某个CSS属性-值对的时候,该CSS代码块才会生效。

举一个简单的例子,下面的代码中,只有当浏览器支持display: flex的时候才会应用Flexbox样式。

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

另外也可以使用一些操作符,比如andnot,我们就可以创建更复杂的特征查询。例如,我们可以识别一个浏览器是否支持老版本的Flexbox语法。

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

浏览器支持

拓展

Feature Queries同样支持Javascript接口:CSS.supports(),同样使用上面的例子,看下如何使用:

if ( CSS.supports( '(display: flex)') ) { console.log('支持flex') } else { console.log('不支持flex') } if ( CSS.supports( '(display: flexbox)' ) ) { console.log('支持flexbox') } else { console.log('不支持flexbox') }

2. Grid Layout(栅格布局)

定义了一个创建以网格为基础的布局系统。这和相似,但栅格布局是专门为页面布局设计,因此有很多不同的特性。

Explicit Item Placement

一个栅格系统是由栅格容器(Grid Containe,由display: grid创建)、栅格项(Grid Item)组成。在我们的CSS中,我们可以很容易且明确的组织布局以及栅格项的顺序、与标记中的布局相独立。

例如,我在一文中如何使用栅格布局模块创建圣杯布局。

主要的HTML代码:

 
Title
Content
Footer

主要的CSS代码:

.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属性可以完成这项工作,这些属性接受一个<length-percentage>百分比数据类型作为值,与内容区域的尺寸对应的百分比。

例如,有5%的空隙,可以这样写:

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

浏览器支持

CSS网格模块将最早在今年三月在浏览器中可用(提供默认支持)。

现在想体验怎么办?

参考我的这篇记录:。

3、Native Variables

最后一个是。该模块介绍了创建用户自定义变量的方法,可以给一个CSS属性分配一个变量。

例如,如果我有一个主题色,这个主题色被用在了好几个地方,这时候,就可以抽象这个主题色到一个变量中,并且在使用的时候引用这个变量,这样比把这个颜色写到多个地方更容易维护。

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

这种效果在之前我们一般借助CSS预处理器来实现,比如SASS,但是CSS变量有个优点就是一直存在于浏览器中。这意味着这些变量值可以在线修改。例如,为了更新--theme-colour属性值,可以通过如下方式:

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

浏览器支持

2017年什么CSS特性最让你激动?

转载地址:http://vrqbm.baihongyu.com/

你可能感兴趣的文章
js-数据运算
查看>>
解决阿里云ECS运行前后台分离项目调用QQ互联导致: redirect uri is illegal(100010)问题...
查看>>
Slog48_项目上线之域名的备案
查看>>
[ 一起学React系列 -- 1 ] 信笔说JSX
查看>>
homebrew报错问题解决
查看>>
肉眼看到的相同两个字串的不同
查看>>
ng-zorror@~0.6升级@^1在开发中有哪些差异
查看>>
微信小程序 request请求封装
查看>>
Git 学习
查看>>
ES6深入浅出 模块系统
查看>>
一道js闭包面试题的学习
查看>>
微信小程序(新)必备知识
查看>>
网站接入微信扫码登录并获取用户基本信息(微信开放平台)
查看>>
HTC VIVE Wave 概览
查看>>
Vue动态控制input的disabled属性
查看>>
TCP的局限性有哪些?
查看>>
【前端数据结构基础】栈
查看>>
沙漠种水稻,88岁的袁隆平又创造奇迹!他参与的“袁米”还有个大计划
查看>>
JS基础入门篇(二十四)—DOM(上)
查看>>
阿里架构师眼里JVM可以说的那些事
查看>>