呜啦!日常碎碎念,偶尔掉落优质前端博文推荐、学习资源等
网页:https://tg.cosine.ren
本频道的搜索Bot 来辣 👉 @cosSearchBot
私聊直接发消息就可以搜索啦~
🔖tags
#优质博文 #资源推荐 #博客更新 #碎碎念 #项目更新 #手工 #书摘 #阮一峰的科技周刊 #新动态

图频:Cosine 🎨 Gallery @CosineGallery
猫片: @cosine_cat
联系频道主:@cosine_yu
#书摘 #css #前端
《CSS选择器世界(第2版)》 我是懒狗嘤嘤嘤
微信读书 23个笔记

◆ 第1章 概述

>> CSS选择器可以分为4种,即选择器、选择符、伪类和伪元素。

>> 这里的body就是一种选择器,属于类型选择器,也可以称为标签选择器。

>> 这里的.container也是选择器,属于属性选择器,我们平时称其为类选择器。

>> 目前我所知道的CSS选择器世界中的选择符有5种,即表示后代关系的空格( )、表示父子关系的箭头(>)、表示相邻兄弟关系的加号(+)、表示兄弟关系的波浪线(~),以及表示列关系的双管道(||)。

>> 如今CSS选择器是有局部作用域的概念的。伪类:scope的设计初衷就是匹配局部作用域内的元素。

>> 实际上此特性曾被浏览器支持过,但只是昙花一现,现在已经被舍弃。目前虽然伪类:scope也能解析,但只能当作全局作用域。但是,这并不表示:scope一无是处,它在JavaScript中还是有效的

>> 上面的CSS选择器的局部作用域示例都配有演示页面,读者可以手动输入https://demo.cssworld.cn/selector2/1/2-1.php

>> CSS选择器中还有一个命名空间(namespace)的概念,这里简单介绍一下。命名空间可以让来自多个XML词汇表的元素的属性或样式彼此之间不产生冲突,它的使用非常常见,例如XHTML文档:<html xmlns="http://www.w3.org/1999/xhtml">又如SVG文件的命名空间:<svg xmlns="http://www.w3.org/2000/svg">上述代码中的xmlns属性值对应的URL地址就是一个简单的命名空间名称,并不指向实际的在线地址,浏览器不会使用或处理这个URL。

>> svg|a中有一个管道符|,管道符前面的字符表示命名空间的代称,管道符后面的内容则是选择器。

>> CSS选择器命名空间的兼容性很好,至少10年前浏览器就已支持,但是,很少见人在项目中使用它,这是为什么呢?原因有二。其一,在HTML中直接内联SVG的应用场景并不多,它更多的是作为独立的SVG资源使用,即使内联,也很少有需要对特性SVG标签进行样式控制的需求;其二,有其他更简单的替代方案

>> 当这些无效的CSS选择器和浏览器支持的CSS选择器在代码中一起出现的时候,会导致整个选择器无效。

>> :hover和:active是浏览器很早就支持的两个伪类,按道理讲,所有浏览器都能识别这两个伪类,但是,由于IE浏览器并不支持:focus-within伪类,导致IE浏览器无法识别整个语句,这就是无效CSS选择器特性。


◆ 第2章 CSS声明的优先级

>> 被继承的CSS声明的优先级一定位于整个CSS世界的底层。

>> 日常开发代码>@layer开发代码>插件注入代码>浏览器内置代码。

>> 先讲解一下设计@layer的初衷。

>> 这就会使我们的CSS代码变得很臃肿,维护成本上升,同时过于复杂的选择器也使CSS渲染的性能不是很好。

>> 而有了@layer规则,上面这些问题就迎刃而解了。我们只要将希望获得低优先级的CSS代码放在@layer规则中,就无须再担心选择器优先级过高的问题,因为@layer规则的级联层级比常规的CSS代码的级联层级低。

>> 其优先级低于.container和.some-button这两个类名,但是由于代码所在的级联层级更高,因此,还是重置了30px。

>> 这就是@layer规则的作用,可以让CSS代码的级联层级降低,从而确保主业务的CSS代码不受第三方组件的CSS代码的影响。

>> @layer {rules}语法在前文出现过,没有任何层级名,称为匿名级联层

>> 下面3种语法均需要自定义级联层的名称,称为命名级联层

>> 命名带规则语法

>> 此时,我们可以使用下面的单命名语法或者多命名语法来灵活调整不同级联层的优先级顺序。如果我们没有这样的需求,则可以直接使用匿名级联层语法。
#书摘 #css #前端
《CSS 世界》与众不同的background-position百分比计算方式
1. CSS中有一类属性值被称作 <position> 值,表示一种CSS数据类型、二维坐标空间,用于设置相对盒子的坐标。<position> 值支持1~4个值,可以是具体数值,也可以是百分比值,还可以是left、top、right、center和bottom等关键字。图9-5给出了经典的示意(p1)

- 如果缺省偏移关键字,则会认为是center,因此background-position:top center可以直接写成background-position:top。
- IE8浏览器最多只支持同时出现 2个值,从 IE9 开始支持同时出现 3个值或4 个值,作用是指定定位的偏移计算从哪个方位算起。

2. <position>值的百分比值有着特殊的计算公式:

positionX = (容器的宽度 - 图片的宽度) * percentX;
positionY = (容器的高度 - 图片的高度) * percentY;
#书摘 #css #前端
《CSS 世界》了解 :first-letter 伪元素
很多年前,Chrome浏览器和IE9浏览器还未出现,那时候first-letter叫伪类选择器,写法是前面加一个冒号,如:first-letter。那时候的语义要更直白一些,选择第一个字符,然后设置一些样式。后来,伪类和伪元素被划分得更加明确和规范了,::after、::before、 ::backdrop、::first-letter、::first-line、::selection等是伪元素,:active、 :focus、:checked等被称为伪类,这就导致::first-letter的语义发生了一些变化—首字符作为元素的假想子元素。
1.::first-letter 伪元素生效的前提 要想让::first-letter(:first-letter)伪元素生效,是需要满足一定条件的,而且条件乍一看还挺苛刻。首先,元素的display计算值必须是 block、inline-block、list-item、table- cell 或者 table-caption,其他所有 display 计算值都没有用,包括 display:table和display:flex等。 此外,不是所有的字符都能单独作为::first-letter 伪元素存在的,常见的标点符号、各类括号和引号在::first-letter 伪元素眼中全部都是“辅助类”字符,不算。字符前面不能有图片或者 inline-block/inline-table 之类的元素存在。
2.::first-letter伪元素可以生效的CSS属性 如果字符被选作了::first-letter 伪元素,并不是像::before 伪元素那样,几乎所有CSS都有效,只是一部分有效。因此,如果妄图使用 visibility:hidden 或者 display:none 隐藏::first- letter伪元素,还是省省吧(如p3)
#书摘 #css #前端
《CSS 世界》关于两端对齐
就不多说了,如图,这个方法我也用过,书里写的有点儿感慨:
关于使用空标签心理障碍 —— 「有人对代码有洁癖,原本规整的列表最后加几个空标签,心里难受。这种心理往往出现在新人身上,本质上是因为关注点是代码自身,而不是产品、同事或公司更高层面的东西。于是,当产品经理提需求时,他们想到的是我的代码如何如何,而不是产品收益如何如何。毕竟我们是职场人,很显然,创造收益和价值的意识要远比代码洁癖心理对职业生涯发展帮助更大。回到我们这里,代码排版确实不美了,但是功能很好地实现了,且非常健壮,容错性强,而且对SEO没有任何干扰,对辅助设备访问也没有任何干扰,百益无一害,有什么好难受的呢!」
#书摘 #css #前端
《CSS 世界》white-space 与换行和空格的控制
white-space
属性声明了如何处理元素内的空白字符,这类空白字符包括 Space 键、Enter 键、Tab 键产生的空白。因此,white-space可以决定图文内容是否在一行显示(回车空格是否生效),是否显示大段连续空白(空格是否生效)等。其属性值包括下面这些
- normal 合并空白字符和换行符
- pre 空白字符不合并,并且内容只在有换行符的地方换行
- nowrap :该值和normal一样会合并空白字符,但不允许文本环绕
- pre-wrap 空白字符不合并,并且内容只在有换行符的地方换行,同时允许文本环绕
- pre-line 合并空白字符,但只在有换行符的地方换行,允许文本环绕。

从上面的解释我们可以看出,white-space 的功能分 3 个维度,分别是:是否合并空白字符,是否合并换行符,以及文本是否自动换行。于是我们就可以得到一个更加直观的功能表,如表8-2所示(p2)

1. 合并空格:会让多个空格变成1个,也就是我们平常看到的效果,敲了10个空格,结果页面就1个空格。
2. 合并换行:会把多个连续换行合并成1个,并当作1个普通空格处理,就是键盘空格键敲出来的那个空格。
3. 文本环绕:一行文字内容超出容器宽度时,会自动从下一行开始显示。
#书摘 #css #前端
《CSS 世界》关于 word-break 和 word-wrap
1. 首先了解一下word-break属性,语法如下:

word-break: normal;
word-break: break-all;
word-break: keep-all;

其中的几个关键字值的含义具体解释如下。
- normal :使用默认的换行规则。
- break-all :允许任意非 CJK(Chinese/Japanese/Korean)文本间的单词断行。
- keep-all :不允许 CJK 文本中的单词换行,只能在半角空格或连字符处换行。非 CJK 文本的行为实际上和 normal 一致。

break-all
这个值所有浏览器都支持,但是 keep-all 就不这样了,虽然有一定的发展和进步,但目前移动端还不适合使用 word-break:keep-all 。 另外,Chrome、Safari 以及其他 WebKit 或 Blink 浏览器还支持非官方标准的 break-word 值,其表现就和 word-wrap:break-word 一样,这个知识了解一下即可。

2. 接下来是 word-wrap

word-wrap: normal;
word-wrap: break-word;

- normal :就是大家平常见得最多的正常的换行规则。
- break-word :一行单词中实在没有其他靠谱的换行点的时候换行。
word-wrap 之前由于和 word-break 长得太像,难免会让人记不住或搞混,于是在 CSS3 规范里,这个属性的名称被修改了,叫作 `overflow-wrap`。这个新属性名称显然语义更准确,也更容易区别和记忆。但是,也就 Chrome 和 Safari 等 WebKit 或 Blink 浏览器支持这个新属性。因此,虽然换了个好看好用的新名字,为了兼容性,目前还是乖乖地使用word-wrap吧。(我说怎么这俩一样)

3. 区别:
word-break:break-all 的作用是所有的都换行,毫不留情,一点儿空隙都不放过,而 word-wrap:break-word 则带有怜悯之心,如果这一行文字有可以换行的点,如空格或 CJK(中文/日文/韩文)之类的,就不打英文单词或字符的主意了,在这些换行点换行,至于对不对齐、好不好看则不关心,因此,很容易出现一片一片空白区域的情况。
#优质博文 #折腾
之前不是搭了memos 吗,我发现还有挺多配套的东西,比如如图的ios客户端和安卓上的:
- Moe Memos - 适用于 iOS 和 Android 的第三方客户端
- lmm214/memos-bber - Chrome 扩展
- Rabithua/memos_wmp - 微信小程序
- qazxcdswe123/telegramMemoBot - 电报机器人
- eallion/memos.top - 使用 Memos API 呈现的静态页面
- eindex/logseq-memos-sync - Logseq 插件
- JakeLaoyu/memos-import-from-flomo - 导入数据。来自flomo、微信读书的支持
- 发送到备忘录- iOS 的快捷方式
- 备忘录 Raycast Extension - Raycast 扩展
- Memos Desktop - 适用于 MacOS 和 Windows 的第三方客户端
- MemosGallery - 使用 Memos API 呈现的静态图库
详情请看这篇:Memos:私有、轻量、开源、自托管的备忘录
已经用上了,好舒服
Back to Top