《css揭秘》读书笔记

比特云影
• 阅读 1904

第一章 引言

css编码技巧

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

第二章 背景与边框

半透明边框

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

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

多重边框

《css揭秘》读书笔记

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);

条纹背景

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

《css揭秘》读书笔记

// 水平条纹
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
                    );

这里面涉及一些知识点:

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

复杂的背景图

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

《css揭秘》读书笔记

            // 网格
            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%;

连续的图像边框

《css揭秘》读书笔记

            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属性

虚线框&动态虚线框

《css揭秘》读书笔记

.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%} }

边框裁剪效果

《css揭秘》读书笔记

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

第三章 形状

椭圆

《css揭秘》读书笔记

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

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

平行四边形

《css揭秘》读书笔记

.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%);
}

切角效果

《css揭秘》读书笔记

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;

弧形切角

《css揭秘》读书笔记

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揭秘》读书笔记

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

这本书对于本小开发来说,更多像一本工具类书籍,可以经常翻阅查询,温故知新。举一反三?举一反三是不可能举一反三的,这辈子都不可能举一反三!
点赞
收藏
评论区
推荐文章
Souleigh ✨ Souleigh ✨
4年前
几个有点意思的 CSS 技巧
如果你是一名前端开发人员或者想成为一名开发人员,那么,我今天与你分享的9个CSS技巧,你需要知道一下。现在,我们开始吧。1、学习盒子模型你在学习CSS时,应该避免使用Bootstrap或TailwindCSS等框架,这些工具非常适合构建漂亮的网站,但如果你还不能正确的了解CSS,则建议不要使用这些框架中的任何一个。因为如果你使用了这些工具,你将无法学习
徐小夕 徐小夕
3年前
前端: 如何更高效的学习Css? 有哪些库值得推荐?
之前有很多朋友问我如何快速学习css以及有哪些好用的css库,最近也抽出时间思考整理了一下,今天就和大家分享一下我的经验.如何高效学习Css之前在工作中也使用css做过很多有意思的事情,比如用css画图标,写轮播图,写动效,做布局等等,但是这些应用的实现都依赖于html和css基础知识.根据我自己的学习经验,我们需要掌
徐小夕 徐小夕
4年前
巧用css圆角实现有点意思的加载动画
作为一名前端工程师,需要对css技巧有充分的研究和了解,接下来笔者将会带大家一起掌握如何用css的圆角属性来实现有点意思的加载动画.如果想学习更多css实用技巧,可以参考笔者以下的文章:<divstyle"display:flex;flexwrap:wrap;alignitems:center;"<ahref"https:/
徐小夕 徐小夕
4年前
如何使用css3实现一个类在线直播的队列动画
之前在群里有个朋友问了这样一个问题,就是如何在小程序中实现类似直播平台的用户上线时的队列动画?作为一名前端工程师,解决方案无非以下2种:1.使用javascript根据条件来控制元素的样式实现队列动画2.用纯css3配合数据驱动模型来实现.大家都知道在现代的Web开发中,我们能使用Css实现的效果尽量不要用Js,所以我们应该优先考虑用C
徐小夕 徐小夕
4年前
《前端实战总结》之使用纯css实现网站换肤和焦点图切换动画
今天我们来继续复盘一些工作中常用的css技巧和知识,以便我们可以更加优雅的用css实现富有动感的网站.你将收获网站换肤设计方案介绍:target伪类介绍和用法以及如何使用css实现网站换肤transition动画以及如何用纯css实现焦点图动画效果展示1.网站换肤(https://imghelloworld.ossc
Python进阶者 Python进阶者
3年前
一篇文章带你了解CSS单位相关知识
大家好,我是皮皮,今天给大家分享一些前端的知识。一、了解CSS单位测量长度的单位可以是绝对的,例如像素,点等,也可以是相对的,例如百分比(%)和em单位。指定CSS单位对于非零值是必须的,因为没有默认单位。丢失或忽略单位将被视为错误。但是,如果该值为0,则可以省略该单位(毕竟,零像素与零英寸是一样的)。注意:长度是指距离测量。长度包括数字值
Stella981 Stella981
3年前
Boost(1.69.0) windows入门(译)
<head<title缩进2字符</title<styletype"text/css".yindent,.yblock{padding:1em1em01em;marginright:0;}.yindent{margin:0.7em2em;border:mediumoutset;}.yblock{margin
Stella981 Stella981
3年前
Selenium2学习(六)
前言大部分人在使用selenium定位元素时,用的是xpath定位,因为xpath基本能解决定位的需求。css定位往往被忽略掉了,其实css定位也有它的价值,css定位更快,语法更简洁。这一篇css的定位方法,主要是对比上一篇的xpath来的,基本上xpath能完成的,css也可以做到。两篇对比学习,更容易理解。一、css:属性定位    
Wesley13 Wesley13
3年前
HTML&CSS基础学习笔记1.29
像素和相对长度前面的html博文,我们提到过用属性width、height来设置图片的尺寸,它们的单元都是”px(像素)”。长度单位总结一下,目前比较常用到px(像素)、em、%百分比,要注意其实这三种单位都是相对单位。1、像素像素为什么是相对单位呢?因为像素指的是显示器上的小点(CSS规范中假设“90像素1英寸”)。实际情
Wesley13 Wesley13
3年前
Java web之JSP的CSS样式不起作用
在编写静态页面时,CSS解析没问题;换成jsp之后样式完全丢失。造成这个的原因是,CSS写的相对路,<linkhref"../css/notification.css"rel"stylesheet"type"text/css"/而这个相对路径是按照jsp文件的当前位置写的。但是,在转换成JSP之后,实际上是使用GET
Stella981 Stella981
3年前
CSS 分类 (Classification)
★★CSS分类属性(Classification)★★⑴CSS分类属性允许你控制如何显示元素,设置图像显示于另一元素中的何处,相对于其正常位置来定位元素,使用绝对值来定位元素,以及元素的可见度。⑵下面是常用的属性以及描述:!(https://oscimg.oschina.net/oscnet/00cb565