最近在写活动页面遇到一个效果,在黑色透明蒙层后面的元素要有模糊,毛玻璃的效果,最初想到的就是 filter: blur(2px) ,直接在元素上使用,但是整个子元素都被模糊了,而且蒙层的背景并没有效果,经过百般搜索和尝试,发现还有一个属性可以实现专门针对有透明度的元素做模糊的效果,而且还不会影响到子元素的展示,它就是 backdrop-filter: blur(3px) ,完美的实现了设计稿的要求。
下面就来看看这两个属性的区别,遇到的问题以及解决方案。
filter CSS属性将模糊或颜色偏移等图形效果应用于元素。滤镜通常用于调整图像,背景和边框的渲染。
想要模糊图像或者某个不带透明度的元素,可以直接在元素上加 filter: blur(2px) ,如果这个元素下面有子元素,这样写子元素也会被模糊,解决方法是使用伪元素加定位效果实现:
backdrop-filter CSS 属性可以让你为一个元素后面区域添加图形效果(如模糊或颜色偏移)。 因为它适用于元素 背后 的所有元素,为了看到效果,必须使元素或其背景至少部分透明。
所以给蒙层的后面添加模糊的效果,可以直接在蒙层元素上使用 backdrop-filter: blur(2px); 即可。
这两个属性的使用可以详细的参考 mdn上的描述:
backdrop-filter
filter
但是 以前规范不明确的时候 伪元素 和 伪类 都是写成 :weiyuansu :weilei
为了兼容过去的写法
所以 你的伪元素 写成一个引号的形式 也是可以被解析的
伪元素主要有:E:first-letter/E::first-letter E:first-line/E::first-line E:before/E::before E:after/E::after E::placeholder E::selection
伪类主要有:E:link E:visited E:hover E:active E:focus E:lang(fr) E:not(s) E:root E:first-child E:last-child E:only-child E:nth-child(n) E:nth-last-child(n) E:first-of-type E:last-of-type E:only-of-type E:nth-of-type(n) E:nth-last-of-type(n) E:empty E:checked E:enabled E:disabled E:target @page:first @page:left @page:right
单冒号 双冒号 主要是为了区别 伪元素还是伪类一、首先是C3属性选择器
1 每一个标签都有自己的属性,是吧?要给它一个样式,就可以通过它的属性来找到它。
2 属性选择器的权重是10
3 都有哪些?
- 标签名[属性名]
- 标签
- 标签名[type="属性名"]
- ^= 以icon开始的选出来
- $= 以icon结尾的选出来
- = 代表任意位置,包含该属性的就要选出来
例子
二、结构伪类选择器
语法:
nth-child(n) 释义:
- 想要选哪个n就在那个里面输入数字几就可以了
- 这里的n 可以有特殊数值偶数even 奇数odd 有利于做隔行变色
- n可以是公式
- -n+5选出前5个。
例子
三、ntf-of-type 选择器
先上总结:
- nth-child(n) 选择父元素里面的第一个 n个孩子
- of-type 选择指定类型的元素
例子
四、伪类选择器
方式一 ::before ::after
方式二 :before :after
总结:伪元素前面可以是一个冒号,也可以是两个冒号,不影响结果
例子## CSS选择器
# 标签选择器
# id选择器
# 类选择器
# 后代选择器
# 子元素选择器
# 交集选择器
# 并集选择器
# 兄弟选择器(相邻兄弟选择器/通用兄弟选择器)
# 序选择器(CSS3中最具代表性)
# 属性选择器
# 通配符选择器
# 伪元素选择器
标签选择器
1什么是标签选择器
作用:根据指定的标签名称,在当前界面中找到所有该名称的标签,然后设置属性
2格式:
标签名称{
属性: 值;
}
注意点:
1标签选择器选中的是当前界面中所有的标签,而不能单独选中某一个标签
2标签选择器无论藏得多深都能被选中
3只要是HTML中的标签就可以作为标签选择器
id选择器
1什么是id选择器
作用:根据指定的id名称找到对应的标签,然后设置属性
格式:
#id名称{
属性: 值;
}
注意点:
1每个HTML标签都有一个属性叫做id,也就是说每个标签都可以设置id
2在同一个界面的id名称是不可以重复的
3在编写id选择器时一定要在id名称前面加上#
4
id的名称是有一定的规范的
41if的名称只能由字母/数字/下划线组成
42id名称不能以数字开头
43id名称不能是HTML标签的名称
44在企业开发中一般情况下如果仅仅是为了设置样式,我们不会使用id,因为前端开发中是留给js使用的
类选择器
什么是类选择器
作用:根据指定的类名称找到对应的标签,然后设置属性
格式:
类名称{
属性: 值;
}
注意点:
1每个HTML标签都有一个属性叫做class,也就是说每个标签都可以设置class
2在同一个界面的class名称是可以重复的
3在编写class选择器时一定要在class名称前面加上
4类名的命名规范和id名称的命名规范一样
5类名解释专门用来给某个特定的标签设置样式的
6在HTML中每个标签可以同时绑定多个类名
格式:
<标签名称 class=“类名1 类名2 类名3”>
错误写法
id和class的区别
11
id相当于人的身份z不可以重复
class相当于人的名称可以重复
12
一个HTML标签只能绑定一个id名称
一个HTML表圈可以绑定多个class名称
2id选择器是以#开头
class选择器以开头
3在企业开发中到底使用id选择器还是用class选择器
id选择器一般是给js用的,除非特殊情况,否则不要用id去设置样式
4在企业开发中一个开发人员对类的使用可以看出这个开发人员的技术水平
后代选择器
什么是后代选择器
-作用:找到指定标签的所有特定的后代标签,设置属性
-格式:
标签名称1 标签名称2{
属性: 值;
}
先找到名称叫做标签名称1的标签,然后再在这个标签下面去查找所有名称叫做标签名称2的标签,然后再设置属性
-注意点:
1后代选择器必须用空格隔开
2后代不仅仅是儿子,也包括孙子/重孙子只要最终是放到指定标签中的都是后代
3后代选择器不仅仅可以使用标签名称还可以使用其他选择器
子元素选择器
什么是子元素选择器
-作用:找到所有标签中特定的直接子元素,然后设置属性
-格式:
标签名称1>标签名称2{
属性: 值;
}
先找到名称叫做”标签名称1”的标签,然后再这个标签中找到所有的直接子元素名称叫做”标签名称2”的元素
-注意点:
1子元素选择器只会查找儿子,不会查找其他被嵌套的标签
2子元素选择器,之间需要用>连接,而且不能有空格
3子元素选择器不仅仅可以使用标签名称还可以用其他选择器
4子元素选择器可以通过>符号一直延续下去
1后代选择器和子元素选择器之间的区别
11
后代选择器使用空格作为连接符号
子元素选择器使用>作为连接符号
12
后代选择器会选中指定标签中,所有的特定后代标签
子元素选择器只会选中指定标签中,所有的特定直接标签
2后代选择器和子元素选择器之间的共同点
21
后代选择器和子元素选择器都可以使用标签名称/id名称/class名称来作为选择器
22
后代选择器和子元素选择器都可以通过各自的连接符号一直延续下去
3在企业开发中如何选择
交集选择器
什么是交集选择器
-作用:给所有选择器选中的标签中,相交的那部分标签设置属性
-格式:
选择器1选择器2{
属性: 值;
}
-注意点:
1选择器1和选择器2之间没有任何的连接符号
2选择器可以使用标签的名称/id名称/class名称
3交集选择器仅仅作为了解,企业开发中用的并不多
并集选择器
什么是并集选择器
-作用:给所有选择器选中的标签设置属性
格式:
选择器1,选择器2{
属性: 值;
}
注意点:
1并集选择器必须使用,来连接
22选择器可以使用标签的名称/id名称/class名称
兄弟选择器
1相邻兄弟选择器 CSS2
-作用:给指定选择器后面[紧跟]的那个选择器选中的标签设置属性
格式:
选择器1+选择器2{
属性: 值;
}
注意点:
1相邻兄弟选择器必须通过+连接
2相邻兄弟选择器只能选中紧跟其后面的那个标签,不能选中被隔开的标签
2通用兄弟选择器 CSS3
-作用:给指定的选择器后面的所有选择器选中的所有标签都设置属性
-格式:
选择器1~选择器2{
属性: 值;
}
-注意点:
1通用兄弟选择器必须用~连接
2通用兄弟选择器选中的是指定选择器后面某个选择器选中的标签后面的所有标签
序选择器(CSS3中新增的选择器中最具代表性)
1同级别的第几个
:first-child 选中同级别中的第一个标签
:last-child 选中同级别中的最后一个标签
:nth-child(n) 选中同级别中的第n个标签
:nth-last-child(n) 选中同级别中的倒数第n个标签
:only-child 选中父元素中唯一的子元素
:nth-child(odd) 奇数 选中同级别中的所有奇数个标签
:nth-child(even) 偶数 选中同级别中的所有偶数个标签
:nth-child(xn+y) 选中同级别中的所有的用户自定义的(xn+y)个标签
x和y是用户自定义的,而n是一个计数器,从0开始递增 有多少个标签n就递增多少次
注意点:不区分类型
2同类型的第几个
:first-of-type 选中同级别中同类型的第一个标签
:last-of-type 选中同级别中同类型的最后一个
:nth-of-type(n) 选中同级别中同类型的第n个标签
:nth-last-of-type(n) 选中同级别中同类型的倒数第n个标签
:only-of-type 选中父元素中唯一类型的某个标签
属性选择器
什么是属性选择器
作用: 根据指定的属性名称找到对应标签,然后设置属性
格式:
[attribute]
作用:根据指定的属性名称找到对应的标签,然后设置属性
[attribute=value]
作用:找到有指定属性,并且属性的取值等于value的标签,然后设置属性
最常见的应用场景,就是用于区分input属性
1属性的取值是以什么开头的
[attribute|=value] CSS2
[attribute^=value] CSS3
两者之间的区别:
CSS2中的只能找到value开头并以-和其他内容隔开的标签,而CSS3可以找到以value开头的所有标签
2属性的取值是以什么结尾的
[attribute$=value] CSS3
3属性的取值是否包含某个特定的值的
[attribute~=value] CSS2
[attribute=value] CSS3
两者之间的区别:
CSS2中的只能找到独立的单词,也就是说value用空格和其他内容隔开的标签,而CSS3可以找到包含value的所有标签
通配符选择器
什么是通配符选择器
-作用:给当前界面上所有的标签设置属性
-格式:
{
属性: 值;
}
-注意点:
由于通配符是设置界面上所有的标签的属性,所以在设置前会遍历所有的标签,如果当前界面上的标签比较多,那么性能会比较差,所以企业开发中一般不会使用通配符选择器
1什么是伪元素选择器
伪元素选择器作用就是给指定标签的内容前面添加一个子元素或者给指定标签的内容后面添加一个子元素
格式:
给指定标签的内容前面添加一个子元素
标签名称::before {
属性名称:值;
}
给指定标签的内容后面添加一个子元素
标签名称::before {
属性名称:值;
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)