二、CSS基础

一、选择器(1)

大白话:我们人为认为的解析方式是,从左往右查找,对于浏览器来说,是从右往左查找,解析速度更高。

注:

伪类选择器 - 作用于实际存在的元素,用于描述元素的某种特定状态或关系,如链接的访问状态(:visited)、鼠标悬停状态(:hover)、是否为文档中的第一个子元素(:first-child)等。它们不直接改变元素的结构,而是影响元素在特定条件下的表现样式。

伪元素选择器 -

用于创建并选择元素内的某个特定部分或是在元素前后生成新的、虚拟的内容节点。例如,::before 和::after 可以用来插入额外内容,:first-line 和 :first-letter 分别选择元素首行文本和首字母,::marker 控制列表项标记样式等。这些伪元素并不对应于HTML文档中的实际元素,但可以对其应用样式,如同它们是真实存在的部分一样。在一些老旧浏览器,可能会使用单冒号,这属于历史遗留问题。

注意:官大一级压死人,即使类选择器有10个,也抵不上一个ID选择器。

二、选择器(2)

三、非布局样式(字体)

font-family: 字体

五个字体族:

serif - 衬线字体族

特点:

  • 具有修饰过的笔画,向外展开的或者尖细的末端,或者是带有实际衬线的末端

  • 一笔一划末端(两头)都带点变化装饰,比如宋体笔画末端有毛笔字的感觉

  • 文字末端有差异,在小字号下仍然容易辨认。但在大字号下笔画装饰部分可能会显得模糊或带有锯齿

示例:

  • Times New Roman、MS Georgia

  • 宋体、仿宋

衍生:

  • petit-serif 小衬线字体族

    末端变化不明显,可以当做无衬线

  • slab-serif 雕版衬线字体族

    末端变化非常明显

sans-serif - 非衬线字体族

sans-前缀是法语,发音为/san/,意为"无"

特点:

  • 具有笔画清晰的末端--带有一点或者没有向外展开的,交错笔画,或者其它装饰

  • 与"衬线字体"相比,如果字号比较小,看起来就会有些难以分辨,尤其段落阅读时容易串行

示例:

  • MS Trebuchet、MS Arial、MS Verdana

  • 黑体、幼圆、隶书、楷体

monospace - 等宽字体族

特点:

  • 每个字形都等宽,主要用于英文,中文方块字本来就等宽

示例:

  • Courier、MS Courier New、Prestige

  • 大多数中文字体

cursive - 手写体

特点:

  • 像手写的一样

示例:

  • Caflisch Script、Adobe Poetica

  • 徐静蕾手写体、迷你简黄草、华文行草、少女体

fantasy - 花体

特点:

  • 艺术字,主要用于图片,页面上用的少

示例:

  • WingDings、WingDings 2、WingDings 3、Symbol

  • 萝卜体

使用原则

常识:

  • 一个页面上不要用3,4种甚至更多字体

  • 如非必要,不要在句中改变字体

  • sans-serif用于在线媒体,serif用于打印设备

  • monospace用于打字机和代码

  • 小字号场景不要用sans-serif,衬线字体更容易辨认

最佳实践:

  • sans-serif是页面首选,无衬线

    因为在屏幕显示设备上,衬线会让文字变得难以辨认

  • serif不适合在线阅读,但打印效果很好,适用于页面打印版

    衬线字体在打印的场景更容易阅读,让人更容易清楚区分不同字母。打印机对分辨率的要求更精细(355ppi),高分辨率下细节显示得很清楚,而不会像屏幕显示一样出现模糊

  • monospace用作代码示例

    每个字符等宽,在页面上占据相同的空间,打字机就用这种字体

  • 正文不要用fantasy和cursive

    可以用在图片或者标题栏里

多字体fallback - 示例

点开Computed,右下角有个Rendered Fonts - 告诉你浏览器是用什么渲染的

解释:英文用的"Monaco"字体、中文用的"PingFang SC"

字体fallback机制

在显示文本时,当系统中的某个字体无法使用或不存在时,系统会自动选择一个备用的字体来展示文本,以确保文字能够显示出来。这种机制在各种操作系统和应用程序中广泛应用,以确保用户能够看到预期的文本内容。

在实际生产中的应用:

注:这里如果没找到"Microsoft Yahei"字体,会朝后找使用"serif"衬线字体。

当前机器没有"Microsoft Yahei"字体,使用了衬线字体,这里使用了宋体。

在编写font-family样式时,一般要求写不同平台下的字体,但是考虑到哪个平台下的适用性更强一些,具体书写技巧见下面示例:

大白话上图font-family理解:

先使用"PingFang SC","PingFang SC"字体不存在,使用"Microsoft Yahei",最后实在不行使用等宽字体族。

为什么将"PingFang SC"放前面呢,"Microsoft Yahei"主要在windows平台使用,也有部分mac平台用户安装了"Microsoft Yahei"字体,如果将"Microsoft Yahei"放前面,会导致一部分在mac平台安装了"Micorsoft Yahei"字体的用户,在mac平台使用"Microsoft Yahei"字体。但事实上在mac平台,"Microsoft Yahei"字体显示效果不如"PingFang SC"好,所以将单一平台使用效果好的字体放前面,则这个单一平台优先会使用效果好的字体,然后再将其他字体写到后面,最后写个字体族兜底!

自定义字体

注:这里的src:url("路径") - 路径可以是自定义字体文件的路径,也可以是一个远程的网络地址。

引用远程地址的字体("字体"一般包含在远程css中)

iconfont - 阿里巴巴矢量图标库

iconfont地址:iconfont-阿里巴巴矢量图标库

1.将字体图标加入购物车

2.将加入购物车的字体,加入项目

3.将项目下载到本地

4.参照压缩包中的demo_index.html引入页面

四、非布局样式(行高)

line-height: 行高

行高的构成:

疑问:为什么行高不一样的时候,渲染的高度是一样的?

首先要理解文字的排版三条线,底线、顶线和基线,默认情况下,所有文字都是安装base-line对齐的。

行高决定上下多余的高度,会把外面的盒子撑起来,line-height会撑起来inline-box的高度(占据空间的高度),这些span的inline-box在一行,line-box的高度由最高的那个inline-box的line-height决定(也就是line-box的高度,也可以说行高是由line-box决定的,line-box是由inline-box组成的,inline-box的行高决定了line-box的行高),这里c3样式的span的line-height是最高30px,所以这一正行的line-height为30px。

行高的现象和方案:

注:

1.第一个div(本身没设定line-hight)的行高是(是由lnline-boxx的line-height决定)span的line-height(60px)+上下边框(border 1px), 实际等于62px;

现在一个div的行高是62px,而字体的大小是font-size=20px,这样上下就会各有一个空白区域。

这里有一个非常重要的特性,如果要写一个垂直居中,可以通过line-height的方式来写。

如果还不明白,请参考常用的line-height使内容垂直居中,你真的懂它的原理吗?-CSDN博客

2.字体默认是按照基线对齐的

如果要居中对齐,可以设置vertical-align:middle

注意,

1).vertical-align:top、bottom是分别按照顶线、底线对齐的,所以看起来并不一定对齐。

2).vertical-aligin也可以用像素px来表示,它是基于基线偏移指定像素px,这种方式尽量不要使用,适应性很差。

3.demo3,图片下有一片空白

产生原因:

src是inline元素,是line元素就要遵守行高的构成,所以图片和"文字"是基线对齐的,意味着基线到底线是有一段空白的,就是基线到底线的距离。

解决方案:

1.将img设置为vertical-align:bottom,按底线对齐;

2.src不要按照inline排列了,设置为dispaly:block

但是这样的结果是,图片独占一行,但同时图片的间隙没有了,因为它变成了block元素。

五、非布局样式(背景)

background:背景

注:日常开发中,很少直接通过颜色的方式来设置,更多是用RGB的方式设置颜色。

还可以通过hsl方式设置颜色:

注:

HSL 是一种表示颜色的 CSS 属性值,它代表色相(Hue)、饱和度(Saturation)和亮度(Lightness)。色相(H)是色彩的基本属性,就是平常所说的颜色名称,如红色、蓝色等,取值范围为0到360度。饱和度(S)表示颜色的纯度,取值范围为 0%到 100%,0%表示灰色,100%表示纯色。亮度(L)表示颜色的明暗程度,取值范围也为 0%到 100%,0%表示黑色,100%表示白色。

还可以加上透明度参数,如下图hsla加上0.3的透明度:

同样,还可以使用RGB的16进制的方式设置颜色:

RGB的方式,同样也可以增加透明度:

背景

background-size: 背景大小

background-repeat:背景图片铺排方式

渐变色背景以及多背景叠加

渐变参考文章:CSS3渐变属性_background: linear-gradient-CSDN博客

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>background</title>
    <style>
        body{
            background:yellow;
        }
        .c1{
            height:90px;
            /* background:rgba(255,0,0, .3); */
            /* background:url(./test.png); */
        }
        .c2{
            height:90px;
            /**线性渐变(老写法,现在可能不支持) - 从左边开始,起始颜色为红色,结束颜色为绿色**/
            /* background: -webkit-linear-gradient(left, red, green); */ 
            /*线性渐变(新写法) - 从左边开始,起始颜色为红色,结束颜色为绿色,这种是标准写法,一般从左到右,从上到下的时候,使用这种写法,更多是使用下面的写法*/
            /* background: linear-gradient(to right, red, green); */ 
            /**
                0deg - 从下到上,相当于to top
                45deg - 从左上角到右下角
                90deg - 从左到右,相当于to right
                180deg - 从上到下,相当于to bottom,这是默认值
                270deg或 -90deg - 从右到左,相当于to left
            */
            /**
                基本写法:
                渐变角度 - 180deg、
                起始颜色red、
                结束颜色为green
            */
            /* background: linear-gradient(180deg, red, green); */
            /** 
                添加更多渐变颜色
                渐变角度 - 135deg
                起始颜色为红色
                10% - 颜色为绿色
                50% - 颜色为黄色
                100% - 颜色为蓝色
            */
            /* background: linear-gradient(135deg, red 0, green 10%, yellow 50%, blue 100%); */
            /**
                第一个linear-gradient:从左下角到右上角
                渐变角度 - 135deg
                起始颜色为透明  - transparent 0
                到49.5% - 颜色仍然是透明的,从49.5%到50.5%之间,颜色由绿色
                50.5%到100% - 颜色再次变为透明的
                结束颜色为透明
                第二个linear-gradient:
                反方向再来一条渐变,从右下角到左上角
            */
            background: linear-gradient(135deg, transparent 0, transparent 49.5%, green 49.5%, green 50.5%, transparent 50.5%, transparent 100%),/*设置135度渐变,左上角到右下角*/
                linear-gradient(45deg, transparent 0, transparent 49.5%, red 49.5%, red 50.5%, transparent 50.5%, transparent 100%);
            /**
                background-size: 30px 30px;
                背景的大小,对渐变以及图片也适用,当设置为宽度、高度为30px,图片会平铺
                设置背景图片的大小,默认是auto,也就是图片原始大小,这里设置成30px,图片会按照30px的宽度和高度进行缩放,
                如果图片的宽度和高度都是30px,那么图片会按照30px的宽度和高度进行缩放,如果图片的宽度和高度不是30px,那么图片会按照30px的宽度和高度进行缩放,
               如果图片的宽度和高度都是大于30px,那么图片会按照30px的宽度和高度进行缩放,如果图片的宽度和高度都是小于30px,那么图片会按照图片的原始宽度和高度进行缩放*/
            background-size: 30px 30px;
        }
    </style>
</head>
<body>
    <div class="c1">

    </div>
    <div class="c2">

    </div>
</body>
</html>

具体效果如下:

背景图片和属性(雪碧图)

将height改为900px,这样背景色就漏出来了。

加上background-repeat: no-repeat;

背景图会出现在左上角;

想让图片出现在中间

也可以通过指定像素设置背景图片位置

修改图片大小

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>background</title>
    <style>
        .c1{
            /* 如果拉大高度,图片会产生平铺效果 */
            height:90px;
            /* background - 背景色和背景图设置,之间不需要逗号,这里背景色看不到是因为图片是不透明的,所以看不到 */
            background:red url();
            /* background-repeat - 
                    repeat  默认平铺,背景图片会重复,直到铺满整个元素区域
                    repeat-x 背景图片会重复,直到铺满整个元素宽度
                    repeat-y 背景图片会重复,直到铺满整个元素高度
                    no-repeat 背景图片不重复,只显示一次,不缩放,不偏移,不旋转*/
            background-repeat: no-repeat;
            /* background-position - 背景图片的位置,默认左上角,可以设置偏移量,也可以设置百分比,也可以设置关键字,关键字有:left,right,center,top,bottom */
            /* background-position: center center; */
            /* 背景图片距左边20px,上边30px*/
            /* background-position: 20px 30px; */
            /*
                设置背景图大小
                background-size: 100px 50px; 按像素设置
                background-size: 100% 50%; 按百分比设置
                background-size: 50%;
            */
            background-size:100px 50px;
        }
        .c2{
            width:20px;
            height:20px;
            background:url(./test_bg.png) no-repeat;
            background-position: -17px -5px;
            background-size: 261px 113px;
        }
        .c3{
            width:20px;
            height:20px;
            background:url(./test_bg.png) no-repeat;
            background-position: -169px -23px;
            background-size: 261px 113px;
        }
    </style>
</head>
<body>
    <!-- <div class="c1">

    </div> -->
    <div class="c2">

    </div>
    <!-- <div class="c3">

    </div> -->
</body>
</html>

下面开始雪碧图代码示例:

显示左上角的原型小图标

开始

此时小图标没显示完全,需要偏移!

知识点:

雪碧图(CSS Sprites)是一种CSS图像合并技术,它将多个小图标或背景图像合并到一张大图片上,然后通过CSS的background-imagebackground-position属性来控制页面中不同元素显示这张大图片的不同部分。以下是关于雪碧图定位计算的详细解释:

1)、background-position属性

background-position:背景图形位置

background-position属性用于设置背景图像的起始位置。它有两个属性值,分别代表水平位置和垂直位置,可以单独设置,也可以同时设置。属性值可以是长度值(如px)、百分比或关键字(如left、right、top、bottom、center)。

2)、雪碧图定位计算原理

  1. 确定雪碧图中小图标的位置

    • 在制作雪碧图时,需要记录每个小图标在雪碧图中的起始位置(x,y坐标)。
  2. 设置元素的背景图像

    • 使用CSS的background-image属性将雪碧图设置为元素的背景图像。
  3. 计算并设置background-position

    • 根据需要显示的小图标在雪碧图中的位置,计算并设置background-position属性的值。
    • 由于容器的尺寸通常小于雪碧图的尺寸,因此background-position的值通常为负值,表示背景图像需要向左或向上移动,以在容器中显示正确的小图标部分。

3)、定位计算的示例

假设有一个雪碧图,其中包含了多个小图标,每个小图标的尺寸都是50px×50px,且它们在雪碧图中的排列是水平的。现在需要在一个尺寸为50px×50px的容器中显示雪碧图中的第二个小图标。

  1. 确定小图标的位置

    • 第一个小图标的起始位置是(0,0)。
    • 第二个小图标的起始位置是(50px,0),即水平方向上偏移了50px。
  2. 设置元素的背景图像

html 复制代码
.icon {
	width: 50px;
	height: 50px;
	background-image: url('path/to/sprites.png');
	background-repeat: no-repeat;
}

3.计算并设置background-position

  • 由于容器尺寸与小雪碧图标尺寸相同,且需要显示第二个小图标,因此需要将背景图像向左移动50px(即第一个小图标的宽度),以显示第二个小图标。
  • 所以,background-position的值应设置为(-50px,0)。
bash 复制代码
.icon2 {
	background-position: -50px 0;
}

4)、注意事项

  1. 确保雪碧图制作正确:在制作雪碧图时,需要确保每个小图标之间的间隔适当,且整个雪碧图的尺寸合理。
  2. 考虑容器尺寸 :在设置background-position时,需要考虑容器的尺寸以及需要显示的小图标在雪碧图中的位置。
  3. 使用负值进行定位 :由于容器的尺寸通常小于雪碧图的尺寸,因此在使用background-position进行定位时,通常需要使用负值来移动背景图像。
  4. 雪碧图使用流程https://zhuanlan.zhihu.com/p/23873229?from_voters_page=true

前面我们知道background-size可以改变图片大小,但是如果在使用雪碧图的时候,改变图片大小,会产生一些其他问题。

改变图片显示容器大小,会导致图片显示不全

将图片大小减小后,发现图片是图片大小合适了,但是定位不对了,需要再次修改图片定位,具体大小以及定位的计算(根据width、height缩减或扩容变动比例,大致以相同比例修改background-position、background-size)

现在图标又可以正常显示了。

什么情况下会遇到上面需要调整大小的场景呢,是在移动端的时候,会调整大小,也就是一般说的高清屏、几倍图等等,也就是本章学习内容""多分辨率适配"。

base64和性能优化

原理:将一张图片转化为base64内容,不再是一张图片地址

优点:

1.节省http请求

缺点:

1.增大图片体积,大致能比原来图片大小增大1/3.

2,以前图片是单独的文件,现在等于将图片放在了CSS中,CSS文件的体积会增大。

3.浏览器拿到图片后,需要进行解码,增加了浏览器解码的开销。

4.在开发阶段,base64图片不容易看到图片内容,一般开发阶段,还是设置的图片路径,在生产打包阶段,会转为base64图片。

所以,一般这种方式,只适用于非常小的图标,少量图标的情况下,去减少http请求。

六、非布局样式(边框)

基本用法

border用法:可以参考【CSS】border 属性详解:边框的全面指南_css border-CSDN博客

使用图片设置边框

border-image是CSS中的一个属性,它允许开发者使用图片或渐变来定义元素的边框,替代了传统的纯色边框,为元素的边框装饰提供了更灵活和自定义的方式。以下是对border-image的详细解释:

1)、基本语法

border-image:边框图片

border-image属性实际上是一个简写属性,它聚合了多个子属性,包括用于定义图片源、切片方式、边框宽度、外扩以及平铺模式的设置。其基本语法如下:

html 复制代码
border-image: source slice width outset repeat | initial | inherit;
  • source:定义用作边框的图片的路径或渐变。
  • slice:定义如何从源图像中切割边框图像。可以指定四个值,分别对应上、右、下、左的切割尺寸,也可以使用两个值或一个值进行简写。
  • width:定义边框图像的宽度。
  • outset:定义边框图像如何超出元素的边框区域。
  • repeat:定义边框图像在边框区域内的平铺方式,可以是repeat(重复)、round(重复并拉伸以适应边框区域)或stretch(拉伸)。

2)、子属性详解

  1. border-image-source

    • 用于指定用作边框图像的URL。如果未设置此属性或值为none,则不会显示边框图像。
  2. border-image-slice

    • 定义如何从源图像中切割边框图像。可以指定四个值(上、右、下、左),也可以使用两个值(上下、左右)或一个值(四边相同)进行简写。
    • 可以使用fill关键字,表示使用整个图像作为边框,不进行切割。
  3. border-image-width

    • 定义边框图像的宽度。可以指定四个值(上、右、下、左),也可以使用两个值(上下、左右)或一个值(四边相同)进行简写。
    • 如果未设置此属性,则使用border-width属性的值。
  4. border-image-outset

    • 定义边框图像如何超出元素的边框区域。可以指定四个值(上、右、下、左),也可以使用两个值(上下、左右)或一个值(四边相同)进行简写。
    • 正值表示边框图像向外扩展,负值表示边框图像向内收缩。
  5. border-image-repeat

    • 定义边框图像在边框区域内的平铺方式。可以是以下值之一:
      • repeat:重复图像以填充边框区域。
      • round:重复图像并拉伸以适应边框区域。
      • stretch:拉伸图像以填充边框区域(这是默认值)。

3)、使用示例

以下是一个使用border-image属性的示例:

html 复制代码
.box {
    width: 128px;
    height: 128px;
    border: 10px solid;
    border-image-source: url("./border.png");
    border-image-slice: 30 fill;
    border-image-width: 10px;
    border-image-outset: 5px;
    border-image-repeat: stretch;
    outline: 1px solid red;
}

在这个例子中,我们定义了一个.box类,它使用一张名为'border.png'的图片作为边框。我们设置了切割方式为fill(使用整个图像),边框宽度为10px,边框图像向外扩展5px,并且图像在边框区域内拉伸以适应。此外,我们还添加了一个红色的outline来显示边框的位置。

4)、注意事项

  1. border-image属性不影响盒子模型的尺寸,边框图像的大小调整不会改变元素的实际宽度和高度。
  2. 如果未设置border-image-source属性或值为none,则不会显示边框图像。
  3. border-image属性可以与border-width、border-style等属性一起使用,但它们不会改变border-image的效果。

课程示例:

边框衔接(三角形)

两条边的衔接处会是什么样子的呢,编辑下代码

发现,边与边交接的地方,是斜切过来的。

将右边变成透明色,会变成什么样,继续改代码:

将左边也变成透明的,会是什么样子,等腰梯形?

继续修改,如果将div的宽度缩小,又会出现什么效果呢?

width: 0px

如果要改变三角形的角度怎么办?只需要继续缩减左右边框的宽度即可

加个圆角

border-radius:10px

底边变成了一个扇形。

七、非布局样式(滚动)

overflow: 滚动条处理

演示代码

注意:使用系统不一样,样式显示效果稍有差异。

八、非布局样式(文本折行)

overflow-wrap: 当内容超过指定容器的边界时是否断行

以前叫word-warp,因为跟work-break太相似,所以在新的规范中进行了修改叫overflow-wrap,实际上overflow-wrap的兼容性不是很好,不如word-wrap,所以,在实际使用中,我们很多时候更多还是使用word-wrap;

  • 是否保留单词 如果一个单次超长,则不会换行。

word-break: 设置或检索对象内文本的字内换行行为

是否将单词看作一个单位,可以设置单词是一个单位,也可以设置字母是一个单位,还可以设置中文句子是一个单位,让它进行换行;

white-space:元素内空白的处理方式,在空白处是否可以断行。

课程示例:

将overflow-warp: break-word,看下效果

设置为break-word,单词换行被打断,进行了折行,这时换行依旧会尽量保持单词的完整性。

将word-break:break-all,看下效果

可以看到,所有的单词都被打断了,没有保持单词的完整性。

设置word-break:keep-all,允许在单词内打断,但是所有的单词都会保持完整性,看下效果:

可以看到,英文单词保持了完整性,但同时,中文句子也保持了完整性。

将white-space:nowrap,一般常用的,只会用到一个值nowrap(不用换行),看下效果:

九、非布局样式(装饰性属性)

font-weight:字重(粗体)

课程示例:

注意:不同的浏览器对font-weight支持的数值不一样,这个需要实际去测试使用。而且bolder和lighter具体对应数值是不一定的,这取决于父级继承下来的值是多少。如果父级是200,那么可能是300/400,如果是500,那么就可能是600/700。

font-style:字体样式

常用:font-style: italic 斜体

text-decoration: 文本装饰

常用:text-decoration: underline 下划线

cursor:鼠标移动到元素上的样式

常用:cursor:pointer 手指

十、hack和案例(1)

所谓CSS Hack,是看起来不像CSS或者用法比较偏门,兼容某些特定版本的浏览器(即不合法但生效)的写法,的称之为CSS Hack。

场景举例:在通用的浏览器上是100px,但是在IE上显示为120px,这时对特定IE浏览器设置为80px,这就是处理特定浏览器版本兼容性的办法,也是CSS Hack。

注意:

1)使用CSS Hack的方式,优点是简单粗暴,缺陷是难理解、难维护、易失效,可能官方升级一下浏览器版本,CSS Hack就失效了,它的替代方式是,判断浏览器版本针对性加clss,这也是推荐用法。

2)使用CSS Hack时,要注意,标准写法写在前, CSS Hack 写在后面。

如下面写法,在标准浏览器的通用写法为宽度200px,在IE需要显示180px,才能保持一致。

十一、hack和案例(2)

课程案例:

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>checkbox</title>
    <style>
        .checkbox{

        }
        .checkbox input{
            display: none;
        }
        .checkbox input + label{
            background:url(./checkbox1.png) left center no-repeat;
            background-size:20px 20px;
            padding-left:20px;
        }
        .checkbox input:checked + label{
            background-image:url(./checkbox2.png);
        }
    </style>
</head>
<body>
    <div class="checkbox">
        <input type="checkbox" id="handsome"/>
        <label for="handsome">我很帅</label>
    </div>
</body>
</html>

​​​​​​​

实现原理:

图片对钩前面有个checkbox隐藏了,上图看到的对钩图片以及文字,其实都在label中,点label相当于点checkbox,当选中或未选中时,分别是对应效果。

注意,这里".checkbox input + label ",这里"+"的含义是当前input相邻的label元素。

十二、面试题

​​​​​​​

相关推荐
庸俗今天不摸鱼33 分钟前
【万字总结】前端全方位性能优化指南(十)——自适应优化系统、遗传算法调参、Service Worker智能降级方案
前端·性能优化·webassembly
QTX1873033 分钟前
JavaScript 中的原型链与继承
开发语言·javascript·原型模式
黄毛火烧雪下40 分钟前
React Context API 用于在组件树中共享全局状态
前端·javascript·react.js
Apifox1 小时前
如何在 Apifox 中通过 CLI 运行包含云端数据库连接配置的测试场景
前端·后端·程序员
一张假钞1 小时前
Firefox默认在新标签页打开收藏栏链接
前端·firefox
高达可以过山车不行1 小时前
Firefox账号同步书签不一致(火狐浏览器书签同步不一致)
前端·firefox
m0_593758101 小时前
firefox 136.0.4版本离线安装MarkDown插件
前端·firefox
掘金一周1 小时前
金石焕新程 >> 瓜分万元现金大奖征文活动即将回归 | 掘金一周 4.3
前端·人工智能·后端
三翼鸟数字化技术团队1 小时前
Vue自定义指令最佳实践教程
前端·vue.js
Jasmin Tin Wei2 小时前
蓝桥杯 web 学海无涯(axios、ecahrts)版本二
前端·蓝桥杯