从知乎首页用户操作入口学习到的CSS技巧 - 合理利用伪元素实现一些装饰样式
最近在模仿做一个静态的PC版知乎,在模仿的过程中,从知乎工程师的方法中学到了不少知识,比如CSS方面的,以下介绍一个今天学到的伪元素的技巧。
示例

DOM结构为:
<div class="home-entry-box relative clearfix">
<span class="home-entry-box-arrow"></span>
<ul class="pull-left">
<li class="home-entry-item inline-block relative">
<a>
<i class="sprite-home-icon-question-off"></i>
<span>提问</span>
</a>
</li>
<li class="home-entry-item inline-block relative">
<a>
<i class="sprite-home-icon-answer-off"></i>
<span>回答</span>
</a>
</li>
<li class="home-entry-item inline-block relative">
<a>
<i class="sprite-home-icon-post-off"></i>
<span>写文章</span>
</a>
</li>
</ul>
<a class="pull-right"><span class="draft">草稿</span></a>
</div>
在这个示例中,标注了两处,第一处是一个装饰之类的东西,这个装饰让整个用户操作导航条好看了不少;第二处是项与项之间的分隔装饰。(为了命名方便,后文中第一处叫做对话修饰,第二处叫做分隔修饰)
实现
分隔修饰: 由于分隔修饰比对话修饰更简单一些,所以先说下分隔修饰的实现。一般情况下,我会想到用border-right去实现这个效果,但这有个问题,效果中这个修饰的高度既不是每一项的高度,也不是每一项的内容的高度,因此用border是不太好处理的,并且也不太方便定位的控制。在这里,可以使用伪元素,将每一项(li.home-entry-item)设置为position: relative,之后每一项加一个伪元素,决定定位来实现分隔修饰的效果,代码为:
.home-entry-item:after {
content: '';
position: absolute;
width: 1px;
height: 20px;
left: 0;
top: 50%;
margin-top: -10px;
background: #f0f0f0;
}
这样,既实现了高度的控制,又实现了定位的控制。
对话修饰: 这是一个直角三角形,刚开始看到的时候,我以为是一个图片做的小图标,后来审查了一下,发现是巧妙地利用了伪元素做出来的。学习了CSS的同学应该都接触过一个经典例子吧,就是画三角形,思路是将一个元素宽高都设置为0,之后控制三个方向的border为透明,再控制最后一个方向的border即可。另外还可以通过控制不同方向border的宽度来实现不同形状的三角形。
这里我们就可以利用伪元素来画这个三角形,不过仔细看的话,会发现示例中的三角形还是一个有边框的三角形,这也是我一开始以为是图片做的图标的原因。后来看了一下知乎的工程师的处理方式,发现自己CSS的使用和创造力还有很多要学习的地方。解决办法是:每个元素正好有两个伪元素,只要再利用一个伪元素画一个三角形,再把两个伪元素画的三角形叠加起来就可以了。其中一个三角形要比另一个小1px的宽高。
示例中的完成方案是通过伪元素画两个等边三角形,其中一个比另一个的border-width小1px,并且垂直距离多偏移1px,水平距离多偏移2px(这样才能让大的三角形包住小的三角形,形成类似边框的效果),之后设置span.home-entry-box-arrow为overflow: hidden; 截去三角形多余的部分,形成直角三角形,这样比直接画直角三角形更省事。代码如下:
.home-entry-box-arrow {
position: absolute;
top: 10px;
left: -10px;
width: 10px;
height: 10px;
overflow: hidden;
}
.home-entry-box-arrow:before,
.home-entry-box-arrow:after {
content: '';
position: absolute;
width: 0;
height: 0;
border: solid transparent;
}
.home-entry-box-arrow:before {
border-top-color: #f0f0f0;
border-width: 14px;
top: 0;
left: 0;
}
.home-entry-box-arrow:after {
border-top-color: #fafafa;
border-width: 13px;
top: 1px;
left: 2px;
}
总结
利用伪元素,可以实现很多装饰效果,善于利用可以写出更好的CSS以及免去不必要的表现型的HTML
从知乎首页用户操作入口学习到的CSS技巧 - 合理利用伪元素实现一些装饰样式的更多相关文章
- [转] 学习使用:before和:after伪元素
http://www.w3cplus.com/css3/learning-to-use-the-before-and-after-pseudo-elements-in-css.html 如果你一直密切 ...
- 【转】学习使用:before和:after伪元素
如果你一直密切关注着各种网页设计的博客,你可能已经注意到了:before和:after伪元素已经在前端开发中获得了相当多的关注.特别是在Nicolas Gallagher的博客中,后期运用了很多伪类元 ...
- 学习使用:before和:after伪元素
http://www.w3cplus.com/css3/learning-to-use-the-before-and-after-pseudo-elements-in-css.html
- 前端学习笔记之CSS后代选择器、子元素选择器、相邻兄弟选择器区别与详解
派生选择器用的很多,派生选择器具体包括为后代选择器.子元素选择器.相邻兄弟选择器,我们来理解一下他们之间的具体用法与区别. 1.css后代选择器语法:h1 em {color:red;} 表示的是从h ...
- 第三百七十六节,Django+Xadmin打造上线标准的在线教育平台—创建用户操作app,在models.py文件生成5张表,用户咨询表、课程评论表、用户收藏表、用户消息表、用户学习表
第三百七十六节,Django+Xadmin打造上线标准的在线教育平台—创建用户操作app,在models.py文件生成5张表,用户咨询表.课程评论表.用户收藏表.用户消息表.用户学习表 创建名称为ap ...
- 微软企业库5.0 学习之路——第九步、使用PolicyInjection模块进行AOP—PART4——建立自定义Call Handler实现用户操作日志记录
在前面的Part3中, 我介绍Policy Injection模块中内置的Call Handler的使用方法,今天则继续介绍Call Handler——Custom Call Handler,通过建立 ...
- HBase实践案例:知乎 AI 用户模型服务性能优化实践
用户模型简介 知乎 AI 用户模型服务于知乎两亿多用户,主要为首页.推荐.广告.知识服务.想法.关注页等业务场景提供数据和服务, 例如首页个性化 Feed 的召回和排序.相关回答等用到的用户长期兴趣特 ...
- delphi操作xml学习笔记 之一 入门必读
Delphi 对XML的支持---TXMLDocument类 Delphi7 支持对XML文档的操作,可以通过TXMLDocument类来实现对XML文档的读写.可以利用TXMLDocum ...
- 从零开始学习jQuery (四) 使用jQuery操作元素的属性与样式
本系列文章导航 从零开始学习jQuery (四) 使用jQuery操作元素的属性与样式 一.摘要 本篇文章讲解如何使用jQuery获取和操作元素的属性和CSS样式. 其中DOM属性和元素属性的区分值得 ...
随机推荐
- 操作 实例 / dom
响应式:数据改变时会触发其他联动.例如:模板中的数据绑定:计算属性的重新计算: ---------------------------------------------------- vm.$par ...
- [Linux]CentOS与终端破墙
来源:https://www.zybuluo.com/ncepuwanghui/note/954160 参考:https://blog.huihut.com/2017/08/25/LinuxInsta ...
- Java数据类型(Primivite 和引用数据类型!)
一.byte(8位) short(16位) int(32位) long(64位) float(32位) double(64位) boolean(Java虚拟机决定) true 或者false! ...
- Golang源码探索(二) 协程的实现原理(转)
Golang最大的特色可以说是协程(goroutine)了, 协程让本来很复杂的异步编程变得简单, 让程序员不再需要面对回调地狱,虽然现在引入了协程的语言越来越多, 但go中的协程仍然是实现的是最彻底 ...
- cxgrid主从表的从表数据小于主表总数的问题
当从表的数据移动需要和数据源记录同步时,会发生一现象:从表中设定的keyfield记录不连续,显示就会中断. 这样要设置从表的排序,按照主表的关联键在内存表里进行排序 indexFieldNames设 ...
- Maven 打包项目 部署到服务器 重启服务 插件
1.maven插件wagon-maven-plugin自动部署远程Linux服务器 (http://xxgblog.com/2015/10/23/wagon-maven-plugin/) <p ...
- Tomcat Server处理一个http请求的过程
Tomcat Server处理一个http请求的过程 假设来自客户的请求为: http://localhost:8080/wsota/wsota_index.jsp 1) 请求被发送到本机端口8080 ...
- react-redux的使用
在react-redux 框架中,给我提供了两个常用的API来配合Redux框架的使用,其实在我们的实际项目开发中,我们完全可以不用react-redux框架,但是如果使用此框架,就如虎添翼了. 我们 ...
- gradle 排除jar包依赖
1.直接在configuration中排除 configurations { compile.exclude module: 'commons' all*.exclude group: 'org.gr ...
- day51 JS基础
复习 1.字体图标 用i标签, 设置类名, 与第三方字体图标库进行图标匹配 <link rel="stylesheet" href="font-awesome-4. ...