随着 IE8 逐渐退出舞台,很多高级的 CSS 特性都已被浏览器原生支持,再不学下就要过时了。

用 :empty 区分空元素

兼容性:不支持 IE8

/*假如我们有以上列表:*/

<div class="item">a</div>
<div class="item">b</div>
<div class="item"></div> 我们希望可以对空元素和非空元素区别处理,那么有两种方案。 /* 用 :empty 选择空元素:*/
.item:empty {
display: none;
} /*或者用 :not(:empty) 选择非空元素:*/ .item:not(:empty) {
border: 1px solid #ccc;
/* ... */
}

用 :*-Of-Type 选择元素

兼容性:不支持 IE8

/* 给第一个 p 段落加粗:*/
p:first-of-type {
font-weight: bold;
}
/* 给最后一个 img 加边框:*/
img:last-of-type {
border: 10px solid #ccc;
} /* 给无相连的 blockquote 加样式:*/
blockquote:only-of-type {
border-left: 5px solid #ccc;
padding-left: 2em;
} /* 让奇数列的 p 段落显示红色:*/
p:nth-of-type(even) {
color: red;
} 此外,:nth-of-type 还可以有其他类型的参数: /* 偶数个 */
:nth-of-type(even) /* only 第三个 */
:nth-of-type(3) /* 每第三个 */
:nth-of-type(3n) /* 每第四加三个,即 3, 7, 11, ... */
:nth-of-type(4n+3)

用 calc 做流式布局

兼容性:不支持 IE8

/* 左中右的流式布局:*/

nav {
position: fixed;
left:;
top:;
width: 5rem;
height: 100%;
} side {
position: fixed;
right:;
top:;
width: 20rem;
height: 100%;
} main {
margin-left: 5rem;
width: calc(100% - 25rem);
}

用 vw 和 vh 做全屏滚动效果

兼容性:不支持 IE8

查看Demo

/* vw 和 vh 是相对于 viewport 而言的,所以不会随内容和布局的变化而变。 */

section {
width: 100vw;
height: 100vh; display: flex;
align-items: center;
justify-content: center;
text-align: center; background-size: cover;
background-repeat: no-repeat;
background-attachment: fixed;
} section:nth-of-type(1) {
background-image: url('https://unsplash.it/1024/683?image=1068');
}
section:nth-of-type(2) {
background-image: url('https://unsplash.it/1024/683?image=1073');
}
section:nth-of-type(3) {
background-image: url('https://unsplash.it/1024/683?image=1047');
}
section:nth-of-type(4) {
background-image: url('https://unsplash.it/1024/683?image=1032');
} body {
margin:;
}
p {
color: #fff;
font-size: 100px;
font-family: monospace;
}

用 unset 做 CSS Reset

兼容性:不支持 IE

查看Demo

body {
color: red;
}
button {
color: white;
border: 1px solid #ccc;
} /* 取消 section 中 button 的 color 设置 */
section button {
color: unset;
}

用 column 做响应式的列布局

兼容性:不支持 IE9

查看Demo

nav {
column-count:;
column-width: 150px;
column-gap: 3rem;
column-rule: 1px dashed #ccc;
column-fill: auto;
} h2 {
column-span: all;
}

CSS 高级布局技巧的更多相关文章

  1. 总结与学习DIV+CSS网页布局技巧

    以前用表格布局时设置网页居中非常方便,把表格对齐方式设置为居中就行了,就这么简单,现在呢,用DIV+CSS样式表控制,好像不是那么容易了,其实也很简单,只不过方式不同而已. <style> ...

  2. CSS高级布局

    float属性 基本浮动规则 先来了解一下block元素和inline元素在文档流中的排列方式. block元素通常被现实为独立的一块,独占一行,多个block元素会各自新起一行,默认block元素宽 ...

  3. 详解 CSS 居中布局技巧

    水平居中元素: 通用方法,元素的宽高未知 方式一:CSS3 transform .parent { position: relative; } .child { position: absolute; ...

  4. 详解CSS居中布局技巧

    本文转自:https://zhuanlan.zhihu.com/p/25068655#showWechatShareTip一.水平居中元素: 1.通用方法,元素的宽高未知方式一:CSS3 transf ...

  5. 20 个 CSS高级样式技巧汇总

    使用技巧会让人变的越来越懒,没错,我就是想让你变懒.下面是我收集的CSS高级技巧,希望你懒出境界. 1. 黑白图像 这段代码会让你的彩色照片显示为黑白照片,是不是很酷? img.desaturate ...

  6. CSS常用布局技巧 实例

    末尾用省略号! white-space: nowrap; overflow: hidden; text-overflow: ellipsis; ######################## 两个i ...

  7. DIV+CSS一些小小的技巧

    DIV+CSS网页布局技巧实例1:设置网页整体居中的代码 以前用表格布局时设置网页居中非常方便,把表格对齐方式设置为居中就行了,就这么简单,现在呢,用DIV+CSS样式表控制,好像不是那么容易了,其实 ...

  8. DIV+CSS常用网页布局技巧!

    以下是我整理的DIV+CSS常用网页布局技巧,仅供学习与参考! 第一种布局:左边固定宽度,右边自适应宽度 HTML Markup <div id="left">Left ...

  9. CSS之定位布局(position,定位布局技巧)

    css之定位 1.什么是定位:css中的position属性,position有四个值:absolute/relative/fixed/static(绝对/相对/固定/静态(默认))通过定位属性可以设 ...

随机推荐

  1. Sql Server 2016 新功能——内置的 Temporal Tables

    放假之前老大跟我提起了一下2016有个有趣的功能叫 Temporal Table ,今天去看了一下资料整理一下. 这个功能看上去像是临时表,但是其实是系统维护的一个历史记录表.(在某个程度上面比起我们 ...

  2. 利用Oracle创建数据库

    本文仅用于学习交流,商业用途请支持正版!转载请注明:http://www.cnblogs.com/mxbs/p/6217151.html 数据库的创建 打开"所有程序"-" ...

  3. iOS CoreAnimation详解(一) 有关Layer的动画

    以前由于项目需要 也写了一些动画 ,但是知识不系统,很散.这段时间趁着项目完成的空袭,来跟着大神的脚步系统的总结一下iOS中Core Animation的知识点. 原博客地址:http://blog. ...

  4. Spring.net 配置说明

    Spring.net使用说明   使用方法: 1.在配置文件设置Spring.net 节点  在配置节中,声明Spring.net,配置 context,objects 标签,来源(type) < ...

  5. python网络编程-TCP协议中的三次握手和四次挥手(图解)

    建立TCP需要三次握手才能建立,而断开连接则需要四次握手.整个过程如下图所示: 先来看看如何建立连接的. 首先Client端发送连接请求报文,Server段接受连接后回复ACK报文,并为这次连接分配资 ...

  6. CentOS配置git和maven自动部署java

    #安装Git yum install git #测试是否成功 git -version #正确 #git version 1.7.1 #配置git config --global user.name ...

  7. webpack构建vue项目(再谈配置)

    webpack配置起来确实麻烦,这不,之前用刚配好了vue1+的版本,结果在(部分)安卓机上测试,发现存在开启热加载(dev-server)的情况下不能识别vue语法的问题,试了很多方法,都没能很好的 ...

  8. pip安装使用详解(转)

    pip类似RedHat里面的yum,安装Python包非常方便.本节详细介绍pip的安装.以及使用方法. 1.pip下载安装 1.1 pip下载   1 # wget "https://py ...

  9. 日历插件FullCalendar应用:(一)数据展现

    在博客园逛了很长时间了,它帮助我获得了很多知识,很感谢大家的分享,而自己呢,由于各种纠结一直没提笔写博客,直到我看到了这篇文章http://www.cnblogs.com/zhaopei/p/why_ ...

  10. IIS配置MP3/MP4/OGG/flv等资源文件访问

    配置过程参考:http://www.cnblogs.com/EasonJim/p/4752399.html 以下包含了mp4的mime类型: 323 text/h323 acx application ...