2020年12月-第02阶段-前端基础-CSS Day07

CSS Day07

CSS高级技巧

  • *理解

能说出元素显示隐藏最常见的写法
能说出精灵图产生的目的
能说出去除图片底侧空白缝隙的方法

  • *应用

能写出最常见的鼠标样式
能使用精灵图技术
能用滑动门做导航栏案例

1. 元素的显示与隐藏

  • 目的

让一个元素在页面中消失或者显示出来

  • 场景

类似网站广告,当我们点击关闭就不见了,但是我们重新刷新页面,会重新出现!

1.1 display 显示(重点)

  • *display 设置或检索对象是否及如何显示。
display: none 隐藏对象

display:block 除了转换为块级元素之外,同时还有显示元素的意思。
  • *特点: 隐藏之后,不再保留位置。

2020年12月-第02阶段-前端基础-CSS Day07

实际开发场景:

配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛

1.2 visibility 可见性 (了解)

  • 设置或检索是否显示对象。
visibility:visible ;  对象可视

visibility:hidden;    对象隐藏
  • *特点: 隐藏之后,继续保留原有位置。(停职留薪)

2020年12月-第02阶段-前端基础-CSS Day07

1.3 overflow 溢出(重点)

  • 检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。

属性值 描述 visible

不剪切内容也不添加滚动条
hidden

不显示超过对象尺寸的内容,超出的部分隐藏掉
scroll

不管超出内容否,总是显示滚动条
auto

超出自动显示滚动条,不超出不显示滚动条

2020年12月-第02阶段-前端基础-CSS Day07

实际开发场景:

1.清除浮动
2.隐藏超出内容,隐藏掉,  不允许内容超过父盒子。

1.4 显示与隐藏总结

属性 区别 用途 display

隐藏对象,不保留位置 配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛
visibility

隐藏对象,保留位置 使用较少
overflow

只是隐藏超出大小的部分 1. 可以清除浮动 2. 保证盒子里面的内容不会超出该盒子范围

2. CSS用户界面样式

  • 所谓的界面样式, 就是更改一些用户操作样式,以便提高更好的用户体验。

更改用户的鼠标样式 (滚动条因为兼容性非常差,我们不研究)
表单轮廓等。
防止表单域拖拽

2.1 鼠标样式cursor

设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状。
属性值 描述 default

小白 默认
pointer

小手
move

移动
text

文本
not-allowed

禁止

鼠标放我身上查看效果哦:

<ul>
  <li style="cursor:default">&#x6211;&#x662F;&#x5C0F;&#x767D;</li>
  <li style="cursor:pointer">&#x6211;&#x662F;&#x5C0F;&#x624B;</li>
  <li style="cursor:move">&#x6211;&#x662F;&#x79FB;&#x52A8;</li>
  <li style="cursor:text">&#x6211;&#x662F;&#x6587;&#x672C;</li>
  <li style="cursor:not-allowed">&#x6211;&#x662F;&#x6587;&#x672C;</li>
</ul>

2.2 轮廓线 outline

2020年12月-第02阶段-前端基础-CSS Day07

是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。

outline : outline-color ||outline-style || outline-width
  • 但是我们都不关心可以设置多少,我们平时都是去掉的。 li

最直接的写法是 : outline: 0; 或者 outline: none;

<input type="text" style="outline: 0;">

2.3 防止拖拽文本域resize

2020年12月-第02阶段-前端基础-CSS Day07

实际开发中,我们文本域右下角是不可以拖拽:

<textarea style="resize: none;"></textarea>

2.4 用户界面样式总结

属性 用途 用途 鼠标样式

更改鼠标样式cursor 样式很多,重点记住 pointer
轮廓线

表单默认outline outline 轮廓线,我们一般直接去掉,border是边框,我们会经常用
防止拖拽

主要针对文本域resize 防止用户随意拖拽文本域,造成页面布局混乱,我们resize:none

3. vertical-align 垂直对齐

  • 有宽度的块级元素居中对齐,是margin: 0 auto;
  • 让文字居中对齐,是 text-align: center;

但是我们从来没有讲过有垂直居中的属性。

vertical-align 垂直对齐,它只针对于 行内元素或者 行内块元素

2020年12月-第02阶段-前端基础-CSS Day07
vertical-align : baseline |top |middle |bottom

设置或检索对象内容的垂直对其方式。

  • 注意

vertical-align 不影响块级元素中的内容对齐,它只针对于 行内元素或者 行内块元素
特别是行内块元素, 通常用来控制图片/表单与文字的对齐

3.1 图片、表单和文字对齐

所以我们知道,我们可以通过vertical-align 控制图片和文字的垂直关系了。 默认的图片会和文字基线对齐。

2020年12月-第02阶段-前端基础-CSS Day07

2020年12月-第02阶段-前端基础-CSS Day07

3.2 去除图片底侧空白缝隙

2020年12月-第02阶段-前端基础-CSS Day07
  • 原因

图片或者表单等行内块元素,他的底线会和父级盒子的基线对齐。
就是图片底侧会有一个空白缝隙。

  • 解决的方法就是:

给img vertical-align:middle | top| bottom等等。 让图片不要和基线对齐。

2020年12月-第02阶段-前端基础-CSS Day07

给img 添加 display:block; 转换为块级元素就不会存在问题了。

2020年12月-第02阶段-前端基础-CSS Day07

4. 溢出的文字省略号显示

4.1 white-space

  • *white-space设置或检索对象内文本显示方式。通常我们使用于强制一行显示内容
white-space:normal &#xFF1B;&#x9ED8;&#x8BA4;&#x5904;&#x7406;&#x65B9;&#x5F0F;

white-space:nowrap &#xFF1B;&#x3000;&#x5F3A;&#x5236;&#x5728;&#x540C;&#x4E00;&#x884C;&#x5185;&#x663E;&#x793A;&#x6240;&#x6709;&#x6587;&#x672C;&#xFF0C;&#x76F4;&#x5230;&#x6587;&#x672C;&#x7ED3;&#x675F;&#x6216;&#x8005;&#x906D;&#x9047;br&#x6807;&#x7B7E;&#x5BF9;&#x8C61;&#x624D;&#x6362;&#x884C;&#x3002;

4.2 text-overflow 文字溢出

  • *设置或检索是否使用一个省略标记(…)标示对象内文本的溢出
text-overflow : clip &#xFF1B;&#x4E0D;&#x663E;&#x793A;&#x7701;&#x7565;&#x6807;&#x8BB0;&#xFF08;...&#xFF09;&#xFF0C;&#x800C;&#x662F;&#x7B80;&#x5355;&#x7684;&#x88C1;&#x5207;

text-overflow&#xFF1A;ellipsis &#xFF1B; &#x5F53;&#x5BF9;&#x8C61;&#x5185;&#x6587;&#x672C;&#x6EA2;&#x51FA;&#x65F6;&#x663E;&#x793A;&#x7701;&#x7565;&#x6807;&#x8BB0;&#xFF08;...&#xFF09;

注意

一定要首先强制一行内显示,再次和overflow属性 搭配使用

2020年12月-第02阶段-前端基础-CSS Day07

4.3 总结三步曲

  /*1. &#x5148;&#x5F3A;&#x5236;&#x4E00;&#x884C;&#x5185;&#x663E;&#x793A;&#x6587;&#x672C;*/
      white-space: nowrap;
  /*2. &#x8D85;&#x51FA;&#x7684;&#x90E8;&#x5206;&#x9690;&#x85CF;*/
      overflow: hidden;
  /*3. &#x6587;&#x5B57;&#x7528;&#x7701;&#x7565;&#x53F7;&#x66FF;&#x4EE3;&#x8D85;&#x51FA;&#x7684;&#x90E8;&#x5206;*/
      text-overflow: ellipsis;

5. CSS精灵技术(sprite) 重点

5.1 为什么需要精灵技术

2020年12月-第02阶段-前端基础-CSS Day07

图所示为网页的请求原理图,当用户访问一个网站时,需要向服务器发送请求,网页上的每张图像都要经过一次请
求才能展现给用户。

然而,一个网页中往往会应用很多小的背景图像作为修饰,当网页中的图像过多时,服务器就会频繁地接受和发送
请求,这将大大降低页面的加载速度。

老师告诉你我们为什么需要精灵技术:

为了有效地减少服务器接受和发送请求的次数,提高页面的加载速度。

出现了CSS精灵技术(也称CSS Sprites、CSS雪碧)。

5.2 精灵技术讲解

CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),然而,各个网页元素通常只需要精灵图中
不同位置的某个小图,要想精确定位到精灵图中的某个小图。

2020年12月-第02阶段-前端基础-CSS Day07

这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像即可全部展示出来。

  • *我们需要使用CSS的
1.background-image
2.background-repeat
3.background-position&#x5C5E;&#x6027;&#x8FDB;&#x884C;&#x80CC;&#x666F;&#x5B9A;&#x4F4D;&#xFF0C;
4.&#x5176;&#x4E2D;&#x6700;&#x5173;&#x952E;&#x7684;&#x662F;&#x4F7F;&#x7528;background-position &#x5C5E;&#x6027;&#x7CBE;&#x786E;&#x5730;&#x5B9A;&#x4F4D;&#x3002;

5.3 精灵技术使用的核心总结

首先我们知道,css精灵技术主要针对于背景图片,插入的图片img 是不需要这个技术的。

1.&#x7CBE;&#x786E;&#x6D4B;&#x91CF;&#xFF0C;&#x6BCF;&#x4E2A;&#x5C0F;&#x80CC;&#x666F;&#x56FE;&#x7247;&#x7684;&#x5927;&#x5C0F;&#x548C; &#x4F4D;&#x7F6E;&#x3002;
2.&#x7ED9;&#x76D2;&#x5B50;&#x6307;&#x5B9A;&#x5C0F;&#x80CC;&#x666F;&#x56FE;&#x7247;&#x65F6;&#xFF0C; &#x80CC;&#x666F;&#x5B9A;&#x4F4D;&#x57FA;&#x672C;&#x90FD;&#x662F; &#x8D1F;&#x503C;&#x3002;

5.4 制作精灵图(了解)

CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),那我们要做的,就是把小图拼合成一张大图。

大部分情况下,精灵图都是网页美工做。

&#x6211;&#x4EEC;&#x7CBE;&#x7075;&#x56FE;&#x4E0A;&#x653E;&#x7684;&#x90FD;&#x662F;&#x5C0F;&#x7684;&#x88C5;&#x9970;&#x6027;&#x8D28;&#x7684;&#x80CC;&#x666F;&#x56FE;&#x7247;&#x3002; &#x63D2;&#x5165;&#x56FE;&#x7247;&#x4E0D;&#x80FD;&#x5F80;&#x4E0A;&#x653E;&#x3002;
&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x6A2A;&#x5411;&#x6446;&#x653E;&#x4E5F;&#x53EF;&#x4EE5;&#x7EB5;&#x5411;&#x6446;&#x653E;&#xFF0C;&#x4F46;&#x662F;&#x6BCF;&#x4E2A;&#x56FE;&#x7247;&#x4E4B;&#x95F4;&#x7559;&#x6709;&#x9002;&#x5F53;&#x7684;&#x7A7A;&#x9699;
&#x5728;&#x6211;&#x4EEC;&#x7CBE;&#x7075;&#x56FE;&#x7684;&#x6700;&#x4F4E;&#x7AEF;&#xFF0C;&#x7559;&#x4E00;&#x7247;&#x7A7A;&#x9699;&#xFF0C;&#x65B9;&#x4FBF;&#x6211;&#x4EEC;&#x4EE5;&#x540E;&#x6DFB;&#x52A0;&#x5176;&#x4ED6;&#x7CBE;&#x7075;&#x56FE;&#x3002;

结束语: 小公司,背景图片很少的情况,没有必要使用精灵技术,维护成本太高。 如果是背景图片比较多,可以建议使用精灵技术。

6. 滑动门

先来体会下现实中的滑动门,或者你可以叫做推拉门:

2020年12月-第02阶段-前端基础-CSS Day07

滑动门出现的背景

制作网页时,为了美观,常常需要为网页元素设置特殊形状的背景,比如微信导航栏,有凸起和凹下去的感觉,最
大的问题是里面的字数不一样多,咋办?

2020年12月-第02阶段-前端基础-CSS Day07
&#x4E3A;&#x4E86;&#x4F7F;&#x5404;&#x79CD;&#x7279;&#x6B8A;&#x5F62;&#x72B6;&#x7684;&#x80CC;&#x666F;&#x80FD;&#x591F;&#x81EA;&#x9002;&#x5E94;&#x5143;&#x7D20;&#x4E2D;&#x6587;&#x672C;&#x5185;&#x5BB9;&#x7684;&#x591A;&#x5C11;&#xFF0C;&#x51FA;&#x73B0;&#x4E86;CSS&#x6ED1;&#x52A8;&#x95E8;&#x6280;&#x672F;&#x3002;&#x5B83;&#x4ECE;&#x65B0;&#x7684;&#x89D2;&#x5EA6;&#x6784;&#x5EFA;&#x9875;&#x9762;&#xFF0C;
&#x4F7F;&#x5404;&#x79CD;&#x7279;&#x6B8A;&#x5F62;&#x72B6;&#x7684;&#x80CC;&#x666F;&#x80FD;&#x591F;&#x81EA;&#x7531;&#x62C9;&#x4F38;&#x6ED1;&#x52A8;&#xFF0C;&#x4EE5;&#x9002;&#x5E94;&#x5143;&#x7D20;&#x5185;&#x90E8;&#x7684;&#x6587;&#x672C;&#x5185;&#x5BB9;&#xFF0C;&#x53EF;&#x7528;&#x6027;&#x66F4;&#x5F3A;&#x3002; &#x6700;&#x5E38;&#x89C1;&#x4E8E;&#x5404;&#x79CD;&#x5BFC;&#x822A;&#x680F;&#x7684;&#x6ED1;
&#x52A8;&#x95E8;&#x3002;

https://weixin.qq.com/

核心技术

核心技术就是利用CSS精灵(主要是背景位置)和 盒子padding撑开宽度, 以便能适应不同字数的导航栏。

一般的经典布局都是这样的:

<li>
  <a href="#">
    <span>&#x5BFC;&#x822A;&#x680F;&#x5185;&#x5BB9;</span>
  </a>
</li>

css样式

* {
      padding:0;
      margin:0;

    }
    body{
      background: url(images/wx.jpg) repeat-x;
    }
    .father {
      padding-top:20px;
    }
    li {
      padding-left: 16px;
      height: 33px;
      float: left;
      line-height: 33px;
      margin:0  10px;
      background: url(./images/to.png) no-repeat left ;
    }
    a {
      padding-right: 16px;
      height: 33px;
      display: inline-block;
      color:#fff;
      background: url(./images/to.png) no-repeat right ;
      text-decoration: none;
    }
    li:hover,
     li:hover a {
      background-image:url(./images/ao.png);
    }

总结

1.a &#x8BBE;&#x7F6E; &#x80CC;&#x666F;&#x5DE6;&#x4FA7;&#xFF0C;padding&#x6491;&#x5F00;&#x5408;&#x9002;&#x5BBD;&#x5EA6;&#x3002;
2.span &#x8BBE;&#x7F6E;&#x80CC;&#x666F;&#x53F3;&#x4FA7;&#xFF0C; padding&#x6491;&#x5F00;&#x5408;&#x9002;&#x5BBD;&#x5EA6; &#x5269;&#x4E0B;&#x7531;&#x6587;&#x5B57;&#x7EE7;&#x7EED;&#x6491;&#x5F00;&#x5BBD;&#x5EA6;&#x3002;
3.&#x4E4B;&#x6240;&#x4EE5;a&#x5305;&#x542B;span&#x5C31;&#x662F;&#x56E0;&#x4E3A; &#x6574;&#x4E2A;&#x5BFC;&#x822A;&#x90FD;&#x662F;&#x53EF;&#x4EE5;&#x70B9;&#x51FB;&#x7684;&#x3002;

7. 拓展@

7.1 margin负值之美

1). 负边距+定位:水平垂直居中

咱们前面讲过, 一个绝对定位的盒子, 利用 父级盒子的 50%, 然后 往左(上) 走 自己宽度的一半 ,可以实现盒
子水平垂直居中。

2). 压住盒子相邻边框

2020年12月-第02阶段-前端基础-CSS Day07

7.2 CSS三角形之美

 div {

    width: 0;

    height: 0;
    line-height:0&#xFF1B;
    font-size: 0;
    border-top: 10px solid red;

    border-right: 10px solid green;

    border-bottom: 10px solid blue;

    border-left: 10px solid #000;

 }

一张图, 你就知道 css 三角是怎么来的了, 做法如下:

2020年12月-第02阶段-前端基础-CSS Day07
1.&#x6211;&#x4EEC;&#x7528;css &#x8FB9;&#x6846;&#x53EF;&#x4EE5;&#x6A21;&#x62DF;&#x4E09;&#x89D2;&#x6548;&#x679C;
2.&#x5BBD;&#x5EA6;&#x9AD8;&#x5EA6;&#x4E3A;0
3.&#x6211;&#x4EEC;4&#x4E2A;&#x8FB9;&#x6846;&#x90FD;&#x8981;&#x5199;&#xFF0C; &#x53EA;&#x4FDD;&#x7559;&#x9700;&#x8981;&#x7684;&#x8FB9;&#x6846;&#x989C;&#x8272;&#xFF0C;&#x5176;&#x4F59;&#x7684;&#x4E0D;&#x80FD;&#x7701;&#x7565;&#xFF0C;&#x90FD;&#x6539;&#x4E3A; transparent &#x900F;&#x660E;&#x5C31;&#x597D;&#x4E86;
4.&#x4E3A;&#x4E86;&#x7167;&#x987E;&#x517C;&#x5BB9;&#x6027; &#x4F4E;&#x7248;&#x672C;&#x7684;&#x6D4F;&#x89C8;&#x5668;&#xFF0C;&#x52A0;&#x4E0A; font-size: 0;  line-height: 0;

拓展阅读@

扫一扫下面的二维码,关注我们,获取更多精彩活动资讯,有好礼相送哦~

2020年12月-第02阶段-前端基础-CSS Day07

【腾讯云】618云上GO!云服务器限时秒杀,1核2G首年95元!

2020年12月-第02阶段-前端基础-CSS Day07

【华为云】特惠专区,多款产品限时特价!

2020年12月-第02阶段-前端基础-CSS Day07

【阿里云】上新必买抢先知,劲爆优惠不错过!

2020年12月-第02阶段-前端基础-CSS Day07

【七牛云】优惠专区,多款云产品限时抢购!

2020年12月-第02阶段-前端基础-CSS Day07

【又拍云】免费CDN专区,10G免费大放送!

2020年12月-第02阶段-前端基础-CSS Day07

【知识星球】一个资料分享的站点,各种学习资料,随时分享

2020年12月-第02阶段-前端基础-CSS Day07

微信赞助; 微信打赏 支付宝打赏 支付宝赞助

免责声明:本文所有内容均为互联网上收集而来,仅供学习交流,整理文章为传播相关技术,如有侵权,请联系删除

Original: https://www.cnblogs.com/minvenus/p/Learning-webpage_css8.html
Author: Destiny_Minvenus
Title: 2020年12月-第02阶段-前端基础-CSS Day07

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/586130/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • MySQL PXC集群的实现

    MHA:一主多从,主节点挂了就提升一个从节点作为主节点。 缺点:提升从节点为主节点需要时间,且只有一个节点能进行写操作,所以写的性能不高。 双主架构:两个主节点,两个节点都能进行读…

    Linux 2023年6月7日
    086
  • 干货速看!同行盆友来稿:一文带你搭建K8S高可用集群,以及在上面搭建Prometheus和Grafana。

    写在开篇 kubeadm工具快速部署k8s集群实现故障自动发现、转移及修复,集群中部署prometheus+grafan可实现自动收集集群的各项新性能指标数据,可视化界面提升客户对…

    Linux 2023年6月7日
    099
  • 《拉钩课程 – 重学操作系统 – 计算机组成原理》

    1、芯片是怎么工作的呢?电能供给给芯片,芯片中的一种电子元件晶振(也就是石英晶体)通电后产生震荡,震荡会产生频率稳定的脉冲信号。通常这是一种高频的脉冲信号,每秒可达百万次。然后,我…

    Linux 2023年5月27日
    096
  • IDEA maven项目导包报红线

    原因:没有导入maven包 最后有设置一次,以后就无需设置 1、问题 2、打开Setting 3、将下载好的maven包导入 配置一次,就不用每次都需要配置 1、如果在这个界面先关…

    Linux 2023年6月14日
    0116
  • ElasticSearch & kibana安装

    ElasticSearch ElasticSearch 简介 ElasticSearch 概念 ElasticSearch quick start docker安装ElasticS…

    Linux 2023年6月13日
    0132
  • 【转】我是一个CPU:这个世界慢!死!了!

    简介 经常听到有人说磁盘很慢、网络很卡,这都是站在人类的感知维度去表述的,比如拷贝一个文件到硬盘需要几分钟到几十分钟,够我去吃个饭啦;而从网络下载一部电影,有时候需要几个小时,我都…

    Linux 2023年6月16日
    0152
  • 搭建NFS文件共享系统

    1、概述: NFS(Network File System)意为网络文件系统,它最大的功能就是可以通过网络,让不同的机器不同的操作系统可以共享彼此的文件。简单的讲就是可以挂载远程主…

    Linux 2023年6月7日
    0102
  • Linux 用户密码不能设置问题

    404. 抱歉,您访问的资源不存在。 可能是网址有误,或者对应的内容被删除,或者处于私有状态。 代码改变世界,联系邮箱 contact@cnblogs.com 园子的商业化努力-困…

    Linux 2023年6月7日
    0130
  • k8s集群中网络实现通信原理

    1)安装Docker时,创建一个名为 docke0 的虚拟网桥,虚拟网桥使用”10.0.0.0 -10.255.255.255 “、”172.1…

    Linux 2023年6月14日
    0105
  • Ubuntu报Command ‘firewall-cmd’ not found, but can be installed with: apt install firewalld错误解决方案

    当输入 firewall-cmd –list-ports 查看端口信息时报错 报错的原因可能是没有安装firewall,安装命令为: yum install firewalld …

    Linux 2023年6月7日
    0102
  • ArchLinux安装-2022-01-12

    这篇教程,是我基于B站up住theCW的视频教程整理的,其中添加了一些我在安装n次之后的经验(虽然失败过几次,但我现在安装不会再出差错,所以请放心的看此教程) 当然,我认为theC…

    Linux 2023年5月27日
    094
  • redis主从复制

    Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。 特性: 运行在内存中的数据集工作方式 支持多种数据结构 提供不同级别的磁盘持…

    Linux 2023年5月28日
    086
  • 自制弹窗拦截器

    一个十分简单的bat脚本 如果需要拦截更多弹窗,只需要将第6~8行复制一下并粘贴到:3后面,将所有的SGtool改成要拦截的进程名即可,每添加一个进程,就要将标号加一,我相信你们能…

    Linux 2023年6月6日
    0103
  • 《Redis开发与运维》——(六)Redis复制(脑图)

    posted @2021-01-09 15:05 雪山上的蒲公英 阅读(91 ) 评论() 编辑 / 返回顶部代码 / Original: https://www.cnblogs….

    Linux 2023年5月28日
    082
  • 如何优雅的处理 accept 出现 EMFILE 的问题

    通常情况下,服务端调用 accept 函数会返回一个新的文件描述符,用于和客户端之间的数据传输 在服务器的开发中,有时会遇到这种情况:当调用 accept 函数接受客户端连接,函数…

    Linux 2023年6月13日
    098
  • 一文搞懂docker容器基础:docker镜像管理,docker容器管理

    一.系统环境 二.docker 2.1 Docker 概述 2.2 Docker 平台 2.3 我可以使用 Docker 做什么? 2.3.1 快速、一致地交付您的应用程序 2.3…

    Linux 2023年6月7日
    0154
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球