《css揭秘》读书笔记
第一章 引言
css编码技巧
在引言中,作者提到使用em与inherit来实现css代码的简洁与可维护性。但是根据本司机两年的开发经验来看,在实际开发中很少来使用em这个单位。如何用以及何时去使用,还是要根据实际开发需求来定吧,毕竟这两个属性都有一定的局限性。
第二章 背景与边框
半透明边框
border: 10px solid hsla(0, 0%, 100%, .5);
background: white;
background-clip: padding-box;
background-clip用来指定背景渲染区域
多重边框
box-shadow方案
background: yellowgreen;
box-shadow: 0 0 0 10px #655,
0 0 0 15px deeppink,
0 2px 5px 15px rgba(0, 0, 0, .6);
box-shadow方案有一个缺点就是,shadow不占实际位置,如果有悬浮之类的效果,需要设置相应的内边距来解决这个问题。
outline方案
border: 10px solid #655;
outline: 5px solid deeppink;
outline-offset: 5px;
outline-offset控制偏移
背景定位
background-position扩展语法方案
background: url(example.png) no-repeat bottom right #58a;
background-position: right 20px bottom 10px;
在background属性里面设置背景位置做回退方案
background-origin方案
background-origin用来设定bgposition的基准,默认以padding-box为准,可以将它设置为content-box、border-box来改变这一行为。
calc方案
background-position: calc(100% - 20px) calc(100% - 10px);
条纹背景
水平条纹&垂直条纹&斜条纹
// 水平条纹
background: linear-gradient(#fb3 30%, #58a 0);
background-size: 100% 30px;
// 垂直条纹
background: linear-gradient(90deg, #fb3 50%, #58a 0);
background-size: 30px 100%;
// 斜条纹
background: repeating-linear-gradient(60deg, #fb3, #fb3 15px, #58a 0, #58a 30px);
// 同色系条纹
background: #58a
repeating-linear-gradient(30deg,
hsla(0, 0%, 100%, .1),
hsla(0, 0%, 100%, .1) 15px,
transparent 0,
transparent 30px
);
这里面涉及一些知识点:
- 如果多个色标具有相同的位置,他们会产生一个无限小的过渡区域,颜色会突变
- 如果某个色标的位置值比整个列表中在它之前的色标位置都要小,则色标的位置会被设置为前面所有位置值的最大值,所以这里设置0会取前面的最大值。这么写的目的是减小魔法字符串的影响。
- linear-gradient是css生成的图形,作用于background-image属性,可以通过background-size来控制位置及大小。
- linear-gradient有一个循环版:repeating-linear-gradient。
复杂的背景图
网格&波点&棋盘&伪随机背景
// 网格
width: 400px;
height: 300px;
margin-top: 20px;
background: #58a;
background-image:
linear-gradient(#fff 2px, transparent 0),
linear-gradient(90deg, #fff 2px, transparent 0),
linear-gradient(hsla(0, 0%, 100%, .3) 1px, transparent 0),
linear-gradient(90deg, hsla(0, 0%, 100%, .3) 1px, transparent 0);
background-size: 75px 75px, 75px 75px, 15px 15px, 15px 15px;
// 波点
width: 200px;
height: 150px;
margin-top: 20px;
background: #655;
background-image:
radial-gradient(tan 30%, transparent 0),
radial-gradient(tan 30%, transparent 0);
background-size: 30px 30px;
background-position: 0 0, 15px 15px;
// 棋盘svg方案更优
width: 200px;
height: 150px;
margin-top: 20px;
background: #eee;
background-image: url('data:image/svg+xml,\
<svg xmlns="http://www.w3.org/2000/svg" \
width="100" height="100" \
fill-opacity=".25">\
<rect x="50" width="50" height="50" /> \
<rect y="50" width="50" height="50" /> \
</svg>');
background-size: 30px 30px;
// 伪随机背景,使用质数增加伪随机的真实性
width: 200px;
height: 150px;
margin-top: 20px;
background: hsl(20, 40%, 90%);
background-image:
linear-gradient(90deg, #fb3 11px, transparent 0),
linear-gradient(90deg, #ab4 23px, transparent 0),
linear-gradient(90deg, #655 41px, transparent 0);
background-size: 41px 100%, 61px 100%, 83px 100%;
连续的图像边框
border: 1em solid transparent;
background: linear-gradient(white, white) padding-box,
url(example.jpg) border-box 0 / cover;
/* Styling & enable resize */
width: 21em;
height: 6em;
padding: 1em;
运用background-clips和background-origin属性
虚线框&动态虚线框
.marching {
width: 21em;
height: 6em;
margin: 2em auto;
padding: 1em;
border: 1px solid transparent;
background:
linear-gradient(#fff, #fff) padding-box,
repeating-linear-gradient(-45deg, black 0, black 25%, white 0, white 50%) 0 / .6em .6em;
animation: ants 12s linear infinite;
}
@keyframes ants { to {background-position: 100%} }
边框裁剪效果
.footnote {
margin: 2em auto;
border-top: .2em solid transparent;
border-image: 100% 0 0 linear-gradient(90deg, currentColor 4em, transparent 0);
}
第三章 形状
椭圆
width: 20em;
height: 15em;
background: #f50;
border: 1px solid #ddd;
border-radius: 50% / 100% 100% 0 0;
border-radius可以同时指定水平半径和垂直半径,两组值使用/隔开
平行四边形
.skew {
position: relative;
text-align: center;
width: 5em;
height: 1.6em;
}
.skew::before {
content: '';
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
z-index: -1;
background: #58a;
transform: skew(45deg);
}
菱形图片
辅助元素实现
.picture {
width: 400px;
transform: rotate(45deg);
overflow: hidden;
}
.picture > img {
max-width: 100%;
transform: rotate(-45deg scale(1.42));
}
图片本身放大,在不支持的浏览器里面可以做到版本回退
clip-path版本兼容性不好
.polygon {
clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
transition: 1s clip-path;
}
.polygon:hover {
clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
切角效果
width: 20em;
height: 15em;
margin: 2em auto;
background: #58a;
background:
linear-gradient(-45deg, transparent 15px, #58a 0) right,
linear-gradient(45deg, transparent 15px, #58a 0) left;
background-size: 50% 100%;
background-repeat: no-repeat;
弧形切角
width: 20em;
height: 15em;
margin: 2em auto;
background: #58a;
background: radial-gradient(circle at top left, transparent 15px, #58a 0) top left;
background-size: 50% 50%;
background-repeat: no-repeat;
读后感
这本书介绍了大量的css实现技巧,并且以css3偏多,对于兼容性无要求开发来说,有很大的借鉴价值,比如下图这些梯形框,菱形框,就可以使用css3来实现,减少图片引用成本,并可以增加按钮的灵活性,比如我想加一个点击效果,就只需要动几行css,而无需再加图片(体积)。由于基本都是一些实用性的技巧,我就不一一列举了,建议自读。很好很实用的一本书。
(图片来源:斗鱼客户端英雄联盟官方赛事直播间挂件)
这本书对于本小开发来说,更多像一本工具类书籍,可以经常翻阅查询,温故知新。举一反三?举一反三是不可能举一反三的,这辈子都不可能举一反三!
《css揭秘》读书笔记的更多相关文章
- csapp读书笔记-并发编程
这是基础,理解不能有偏差 如果线程/进程的逻辑控制流在时间上重叠,那么就是并发的.我们可以将并发看成是一种os内核用来运行多个应用程序的实例,但是并发不仅在内核,在应用程序中的角色也很重要. 在应用级 ...
- CSAPP 读书笔记 - 2.31练习题
根据等式(2-14) 假如w = 4 数值范围在-8 ~ 7之间 2^w = 16 x = 5, y = 4的情况下面 x + y = 9 >=2 ^(w-1) 属于第一种情况 sum = x ...
- CSAPP读书笔记--第八章 异常控制流
第八章 异常控制流 2017-11-14 概述 控制转移序列叫做控制流.目前为止,我们学过两种改变控制流的方式: 1)跳转和分支: 2)调用和返回. 但是上面的方法只能控制程序本身,发生以下系统状态的 ...
- CSAPP 并发编程读书笔记
CSAPP 并发编程笔记 并发和并行 并发:Concurrency,只要时间上重叠就算并发,可以是单处理器交替处理 并行:Parallel,属于并发的一种特殊情况(真子集),多核/多 CPU 同时处理 ...
- 读书笔记汇总 - SQL必知必会(第4版)
本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...
- 读书笔记--SQL必知必会18--视图
读书笔记--SQL必知必会18--视图 18.1 视图 视图是虚拟的表,只包含使用时动态检索数据的查询. 也就是说作为视图,它不包含任何列和数据,包含的是一个查询. 18.1.1 为什么使用视图 重用 ...
- 《C#本质论》读书笔记(18)多线程处理
.NET Framework 4.0 看(本质论第3版) .NET Framework 4.5 看(本质论第4版) .NET 4.0为多线程引入了两组新API:TPL(Task Parallel Li ...
- C#温故知新:《C#图解教程》读书笔记系列
一.此书到底何方神圣? 本书是广受赞誉C#图解教程的最新版本.作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式.朴实简洁的文字,并辅之以大量表格和代码示例,全面.直观地阐述了C#语言的各种 ...
- C#刨根究底:《你必须知道的.NET》读书笔记系列
一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...
- Web高级征程:《大型网站技术架构》读书笔记系列
一.此书到底何方神圣? <大型网站技术架构:核心原理与案例分析>通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计 ...
随机推荐
- idea教程--如何申请免费的ideaIDE
开始申请前请先到 https://www.jetbrains.com/zh/student/ 阅读免费学生授权的介绍和常见问题,再依照下方流程进行申请. (1)到 https://www.jetbra ...
- shell日常积累
Linux shell脚本中shift的用法说明 https://blog.csdn.net/zhu_xun/article/details/24796235
- ConvertHelper
DataTable 转Json using Newtonsoft.Json; public static string DataTableToJson(DataTable dt) { varJsonS ...
- python+pytest接口自动化(4)-requests发送get请求
python中用于请求http接口的有自带的urllib和第三方库requests,但 urllib 写法稍微有点繁琐,所以在进行接口自动化测试过程中,一般使用更为简洁且功能强大的 requests ...
- Windows安装face_recognition库
写在前面: 在pip官网搜face_recognition https://pypi.org/project/face_recognition/ 介绍中可看出该包更适合在Linux系统中使用,但也附上 ...
- 有效提升Python代码性能的三个层面
使用python进入一个熟练的状态之后就会思考提升代码的性能,尤其是python的执行效率还有很大提升空间(委婉的说法).面对提升效率这个话题,python自身提供了很多高性能模块,很多大牛开发出了高 ...
- Js-左侧折叠
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Caffe2源码解析之core
写在前面 在对Tensorflow的后端源码进行了拆解(参见tensorflow源码解析系列文章索引)之后,很想跟其它深度学习框架的实现进行对比,根据框架的流行程度,先选择了Pytorch.Pytor ...
- clang的线程安全分析模块 thread safety analysis
介绍 Clang的线程安全分析模块是C++语言的一个扩展,能对代码中潜在的竞争条件进行警告.这种分析是完全静态的(即编译时进行),没有运行时的消耗.当前这个功能还在开发中,但它已经具备了足够的成熟度, ...
- LintCode 练习题
/** * 给定一个链表,旋转链表,将链表每个节点向右移动 k 个位置,其中 k 是非负数. 示例 1: 输入: 1->2->3->4->5->NULL, k = 2 输 ...