第一章 引言

css编码技巧

在引言中,作者提到使用em与inherit来实现css代码的简洁与可维护性。但是根据本司机两年的开发经验来看,在实际开发中很少来使用em这个单位。如何用以及何时去使用,还是要根据实际开发需求来定吧,毕竟这两个属性都有一定的局限性。

第二章 背景与边框

半透明边框

  1. border: 10px solid hsla(0, 0%, 100%, .5);
  2. background: white;
  3. background-clip: padding-box;

background-clip用来指定背景渲染区域

多重边框

box-shadow方案

  1. background: yellowgreen;
  2. box-shadow: 0 0 0 10px #655,
  3. 0 0 0 15px deeppink,
  4. 0 2px 5px 15px rgba(0, 0, 0, .6);

box-shadow方案有一个缺点就是,shadow不占实际位置,如果有悬浮之类的效果,需要设置相应的内边距来解决这个问题。

outline方案

  1. border: 10px solid #655;
  2. outline: 5px solid deeppink;
  3. outline-offset: 5px;

outline-offset控制偏移

背景定位

background-position扩展语法方案

  1. background: url(example.png) no-repeat bottom right #58a;
  2. background-position: right 20px bottom 10px;

在background属性里面设置背景位置做回退方案

background-origin方案

background-origin用来设定bgposition的基准,默认以padding-box为准,可以将它设置为content-box、border-box来改变这一行为。

calc方案

  1. background-position: calc(100% - 20px) calc(100% - 10px);

条纹背景

水平条纹&垂直条纹&斜条纹

  1. // 水平条纹
  2. background: linear-gradient(#fb3 30%, #58a 0);
  3. background-size: 100% 30px;
  4. // 垂直条纹
  5. background: linear-gradient(90deg, #fb3 50%, #58a 0);
  6. background-size: 30px 100%;
  7. // 斜条纹
  8. background: repeating-linear-gradient(60deg, #fb3, #fb3 15px, #58a 0, #58a 30px);
  9. // 同色系条纹
  10. background: #58a
  11. repeating-linear-gradient(30deg,
  12. hsla(0, 0%, 100%, .1),
  13. hsla(0, 0%, 100%, .1) 15px,
  14. transparent 0,
  15. transparent 30px
  16. );

这里面涉及一些知识点:

  1. 如果多个色标具有相同的位置,他们会产生一个无限小的过渡区域,颜色会突变
  2. 如果某个色标的位置值比整个列表中在它之前的色标位置都要小,则色标的位置会被设置为前面所有位置值的最大值,所以这里设置0会取前面的最大值。这么写的目的是减小魔法字符串的影响。
  3. linear-gradient是css生成的图形,作用于background-image属性,可以通过background-size来控制位置及大小。
  4. linear-gradient有一个循环版:repeating-linear-gradient。

复杂的背景图

网格&波点&棋盘&伪随机背景

  1. // 网格
  2. width: 400px;
  3. height: 300px;
  4. margin-top: 20px;
  5. background: #58a;
  6. background-image:
  7. linear-gradient(#fff 2px, transparent 0),
  8. linear-gradient(90deg, #fff 2px, transparent 0),
  9. linear-gradient(hsla(0, 0%, 100%, .3) 1px, transparent 0),
  10. linear-gradient(90deg, hsla(0, 0%, 100%, .3) 1px, transparent 0);
  11. background-size: 75px 75px, 75px 75px, 15px 15px, 15px 15px;
  12. // 波点
  13. width: 200px;
  14. height: 150px;
  15. margin-top: 20px;
  16. background: #655;
  17. background-image:
  18. radial-gradient(tan 30%, transparent 0),
  19. radial-gradient(tan 30%, transparent 0);
  20. background-size: 30px 30px;
  21. background-position: 0 0, 15px 15px;
  22. // 棋盘svg方案更优
  23. width: 200px;
  24. height: 150px;
  25. margin-top: 20px;
  26. background: #eee;
  27. background-image: url('data:image/svg+xml,\
  28. <svg xmlns="http://www.w3.org/2000/svg" \
  29. width="100" height="100" \
  30. fill-opacity=".25">\
  31. <rect x="50" width="50" height="50" /> \
  32. <rect y="50" width="50" height="50" /> \
  33. </svg>');
  34. background-size: 30px 30px;
  35. // 伪随机背景,使用质数增加伪随机的真实性
  36. width: 200px;
  37. height: 150px;
  38. margin-top: 20px;
  39. background: hsl(20, 40%, 90%);
  40. background-image:
  41. linear-gradient(90deg, #fb3 11px, transparent 0),
  42. linear-gradient(90deg, #ab4 23px, transparent 0),
  43. linear-gradient(90deg, #655 41px, transparent 0);
  44. background-size: 41px 100%, 61px 100%, 83px 100%;

连续的图像边框

  1. border: 1em solid transparent;
  2. background: linear-gradient(white, white) padding-box,
  3. url(example.jpg) border-box 0 / cover;
  4. /* Styling & enable resize */
  5. width: 21em;
  6. height: 6em;
  7. padding: 1em;

运用background-clips和background-origin属性

虚线框&动态虚线框

  1. .marching {
  2. width: 21em;
  3. height: 6em;
  4. margin: 2em auto;
  5. padding: 1em;
  6. border: 1px solid transparent;
  7. background:
  8. linear-gradient(#fff, #fff) padding-box,
  9. repeating-linear-gradient(-45deg, black 0, black 25%, white 0, white 50%) 0 / .6em .6em;
  10. animation: ants 12s linear infinite;
  11. }
  12. @keyframes ants { to {background-position: 100%} }

边框裁剪效果

  1. .footnote {
  2. margin: 2em auto;
  3. border-top: .2em solid transparent;
  4. border-image: 100% 0 0 linear-gradient(90deg, currentColor 4em, transparent 0);
  5. }

第三章 形状

椭圆

  1. width: 20em;
  2. height: 15em;
  3. background: #f50;
  4. border: 1px solid #ddd;
  5. border-radius: 50% / 100% 100% 0 0;

border-radius可以同时指定水平半径和垂直半径,两组值使用/隔开

平行四边形

  1. .skew {
  2. position: relative;
  3. text-align: center;
  4. width: 5em;
  5. height: 1.6em;
  6. }
  7. .skew::before {
  8. content: '';
  9. position: absolute;
  10. top: 0;
  11. right: 0;
  12. bottom: 0;
  13. left: 0;
  14. z-index: -1;
  15. background: #58a;
  16. transform: skew(45deg);
  17. }

菱形图片

辅助元素实现

  1. .picture {
  2. width: 400px;
  3. transform: rotate(45deg);
  4. overflow: hidden;
  5. }
  6. .picture > img {
  7. max-width: 100%;
  8. transform: rotate(-45deg scale(1.42));
  9. }

图片本身放大,在不支持的浏览器里面可以做到版本回退

clip-path版本兼容性不好

  1. .polygon {
  2. clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
  3. transition: 1s clip-path;
  4. }
  5. .polygon:hover {
  6. clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  7. }

切角效果

  1. width: 20em;
  2. height: 15em;
  3. margin: 2em auto;
  4. background: #58a;
  5. background:
  6. linear-gradient(-45deg, transparent 15px, #58a 0) right,
  7. linear-gradient(45deg, transparent 15px, #58a 0) left;
  8. background-size: 50% 100%;
  9. background-repeat: no-repeat;

弧形切角

  1. width: 20em;
  2. height: 15em;
  3. margin: 2em auto;
  4. background: #58a;
  5. background: radial-gradient(circle at top left, transparent 15px, #58a 0) top left;
  6. background-size: 50% 50%;
  7. background-repeat: no-repeat;

读后感

这本书介绍了大量的css实现技巧,并且以css3偏多,对于兼容性无要求开发来说,有很大的借鉴价值,比如下图这些梯形框,菱形框,就可以使用css3来实现,减少图片引用成本,并可以增加按钮的灵活性,比如我想加一个点击效果,就只需要动几行css,而无需再加图片(体积)。由于基本都是一些实用性的技巧,我就不一一列举了,建议自读。很好很实用的一本书。

(图片来源:斗鱼客户端英雄联盟官方赛事直播间挂件

这本书对于本小开发来说,更多像一本工具类书籍,可以经常翻阅查询,温故知新。举一反三?举一反三是不可能举一反三的,这辈子都不可能举一反三!

《css揭秘》读书笔记的更多相关文章

  1. csapp读书笔记-并发编程

    这是基础,理解不能有偏差 如果线程/进程的逻辑控制流在时间上重叠,那么就是并发的.我们可以将并发看成是一种os内核用来运行多个应用程序的实例,但是并发不仅在内核,在应用程序中的角色也很重要. 在应用级 ...

  2. CSAPP 读书笔记 - 2.31练习题

    根据等式(2-14) 假如w = 4 数值范围在-8 ~ 7之间 2^w = 16 x = 5, y = 4的情况下面 x + y = 9 >=2 ^(w-1)  属于第一种情况 sum = x ...

  3. CSAPP读书笔记--第八章 异常控制流

    第八章 异常控制流 2017-11-14 概述 控制转移序列叫做控制流.目前为止,我们学过两种改变控制流的方式: 1)跳转和分支: 2)调用和返回. 但是上面的方法只能控制程序本身,发生以下系统状态的 ...

  4. CSAPP 并发编程读书笔记

    CSAPP 并发编程笔记 并发和并行 并发:Concurrency,只要时间上重叠就算并发,可以是单处理器交替处理 并行:Parallel,属于并发的一种特殊情况(真子集),多核/多 CPU 同时处理 ...

  5. 读书笔记汇总 - SQL必知必会(第4版)

    本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...

  6. 读书笔记--SQL必知必会18--视图

    读书笔记--SQL必知必会18--视图 18.1 视图 视图是虚拟的表,只包含使用时动态检索数据的查询. 也就是说作为视图,它不包含任何列和数据,包含的是一个查询. 18.1.1 为什么使用视图 重用 ...

  7. 《C#本质论》读书笔记(18)多线程处理

    .NET Framework 4.0 看(本质论第3版) .NET Framework 4.5 看(本质论第4版) .NET 4.0为多线程引入了两组新API:TPL(Task Parallel Li ...

  8. C#温故知新:《C#图解教程》读书笔记系列

    一.此书到底何方神圣? 本书是广受赞誉C#图解教程的最新版本.作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式.朴实简洁的文字,并辅之以大量表格和代码示例,全面.直观地阐述了C#语言的各种 ...

  9. C#刨根究底:《你必须知道的.NET》读书笔记系列

    一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...

  10. Web高级征程:《大型网站技术架构》读书笔记系列

    一.此书到底何方神圣? <大型网站技术架构:核心原理与案例分析>通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计 ...

随机推荐

  1. Pycharm:命令行参数的设置

  2. C语言刷二叉树(二)基础部分

    102. 二叉树的层序遍历 /** * Definition for a binary tree node. * struct TreeNode { * int val; * struct TreeN ...

  3. LeetCode-268-丢失的数字

    丢失的数字 题目描述:给定一个包含 [0, n] 中 n 个数的数组 nums ,找出 [0, n] 这个范围内没有出现在数组中的那个数. 进阶: 你能否实现线性时间复杂度.仅使用额外常数空间的算法解 ...

  4. 28 面向对象编程 instanceof 代码 小结 父类引用指向子类对象

    instanceof 代码 // main // Object > Person >Student Object object = new Student(); // 提取公式:XY之间是 ...

  5. CF1017F题解

    这种板子题怎么能没有min25筛的题解呢??? 题意:给定一个完全和性函数,求其前缀和.其实普通和性函数也能做就是了 \[\sum_{i=1}^n f(i) \] 类似积性函数,我们把这玩意儿在质数幂 ...

  6. HamsterBear 构建可启动的镜像(更新中)

    HamsterBear 构建可启动的镜像 Allwinner SoC 上电后会执行BootROM中的程序,会依次从SDIO,SPI等接口查询可引导的设备, SPI设备具有最低引导权,若无法查询到可引导 ...

  7. 神经网络中的Heloo,World,基于MINST数据集的LeNet

    前言 最近刚开始接触机器学习,记录下目前的一些理解,以及看到的一些好文章mark一下 1.MINST数据集 MNIST 数据集来自美国国家标准与技术研究所, National Institute of ...

  8. SpringBoot巧用 @Async 提升API接口并发能力

    异步调用几乎是处理高并发Web应用性能问题的万金油,那么什么是"异步调用"? "异步调用"对应的是"同步调用",同步调用指程序按照定义顺序依 ...

  9. 流量回放专题-jvm-sanbox-repeater

    流量回放介绍 一.前言 你是否和我一样遇到过以下的问题? 1)服务重构,一堆接口需要回归,让人头疼 2)每次迭代,都要花很多精力来进行回归测试 3)线上bug,线下复现不了 4)接口自动化用例写辛苦, ...

  10. Arcgis更新sde库许可

    概述 一般来说SDE的试用许可我会建议用户在没有到期之前进行续期,也就是更新许可.否则的话,如果SDE试用许可到期了,除了PostgresSQL数据库之外,我们只能通过SQL语句的方式来进行更新.在到 ...