iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >css中filter属性和backdrop-filter对比有什么区别
  • 187
分享到

css中filter属性和backdrop-filter对比有什么区别

2023-06-08 02:06:31 187人浏览 安东尼
摘要

这篇文章主要为大家展示了CSS中filter属性和backdrop-filter对比有什么区别,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“css中filter属性和backdrop-filter

这篇文章主要为大家展示了CSS中filter属性和backdrop-filter对比有什么区别,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“css中filter属性和backdrop-filter对比有什么区别”这篇文章吧。

filter和backdrop-filter具有一定区别:

  • Filter不仅仅作用于当前元素,后代元素也会继承这个属性,作用于一个空背景元素则没有效果。

  • backdrop-filter 是使透过该层的底部元素模糊化

  • backdrop-filter属性可以让你为一个元素后面区域添加图形效果(如模糊或颜色偏移)。 因为它适用于元素 背后 的所有元素,为了看到效果,必须使元素或其背景至少部分透明。

  • backdrop-filter目前兼容性不佳,尤其是安卓移动端。

filter属性

我们先来说说filter属性,css3中的filter属性简单易用且强大,这些效果作用在图片上可以实现一些特有的特效。而且目前主流浏览器都已经支持了这个属性。

css中filter属性和backdrop-filter对比有什么区别

从上图来看,大部分浏览器的兼容性都是不错的。

我们还是直接用代码来看。

body {  display: flex;  width: 100%;  height: 100vh;  align-items: center;  justify-content: center;}.img {  width: 500px;  height: 500px;}
<body>    <img src="./img/kyoto.jpg" class="img filter"></body>

我们定义一张照片在网页中央,先不做任何处理。

css中filter属性和backdrop-filter对比有什么区别

这是原图呈现的效果。

接下来我们看filter的几个比较重要的属性。

opacity

opacity 代表透明度,值为0-1之间的小数,值越大透明度越低。

.filter{  filter: opacity(.3);}

如下图展示:

css中filter属性和backdrop-filter对比有什么区别

blur

blur可以设置图片使用高斯模糊效果,单位值是px。所谓高斯模糊,就是指一个图像与二维高斯分布的概率密度函数做卷积。

简单点说:高斯模糊常常用来模拟人眼中的物体变远、变快的效果。在照片处理中,我们常常将背景施以高斯模糊,使得背景仿佛变远了,从而突出前景的人物或物体。一些所谓“先拍照,后对焦”的技术利用的也是高斯模糊这个效果。若想弄出视点飞快移动的效果,也可以对背景使用高斯模糊。

.filter {  filter: blur(2px);}

css中filter属性和backdrop-filter对比有什么区别

invert

invert 可以设定反色, 值为0-1之间的小数。

.filter {  filter: invert(1);}

css中filter属性和backdrop-filter对比有什么区别

saturate

saturate可以设定照片饱和度,取值范围为数字即可,默认值1,即100%。

.filter {  filter: saturate(5);}

比如这里我设置饱和度是500%,如下图效果:

css中filter属性和backdrop-filter对比有什么区别

grayscale

grayscale代表灰度,取值在0-1之间,。

.filter {  filter: grayscale(1);}

下图是grayscale为1,即灰度是100%时候的效果。

css中filter属性和backdrop-filter对比有什么区别

另外,如果使用该效果参数里没值的话,也会默认以1,即100%为值取值,即如下面设置。

.filter {  filter: grayscale();}

sepia

sepia代表的是照片褐色,类似于大部分美图软件里的怀旧功能的那种效果,取值也是0-1,和grayscale一样。

.filter {  filter: sepia(1);}

hue-rotate

hue-rotate用来改变图片的色相,默认值为0deg,取值是角度(angle)。

.filter {  filter: hue-rotate(90deg);}

css中filter属性和backdrop-filter对比有什么区别

hue-rotate一般配合css动画使用,可以呈现不一样效果。比如电池充电的动画,随着高度在纵坐标上移,hue-rotate的值逐渐改变,这里因为无法上传git图片,只能看下静态图片:

css中filter属性和backdrop-filter对比有什么区别

css中filter属性和backdrop-filter对比有什么区别

brightness

brightness可以改变图片的亮度,默认值为100%,即1。

.filter {   filter: brightness(2);}

css中filter属性和backdrop-filter对比有什么区别

contrast

contrast代表对比度,这个属性取值和饱和度saturate类似,取值也是数字。

.filter {  filter: contrast(2.5);}

这里我们演示对比度是250%时候的效果,如下图:

css中filter属性和backdrop-filter对比有什么区别

drop-shadow

drop-shadow这个属性类似于box-shadow,给图片加阴影。

.filter {  filter: drop-shadow(20px 20px 10px 20px #000) }

css中filter属性和backdrop-filter对比有什么区别

backdrop-filter属性

我们回过头来在看backdrop-filter属性以下几点特点

  • backdrop-filter 是使透过该层的底部元素模糊化

  • backdrop-filter属性可以让你为一个元素后面区域添加图形效果(如模糊或颜色偏移)。 因为它适用于元素 背后 的所有元素,为了看到效果,必须使元素或其背景至少部分透明。

  • backdrop-filter目前兼容性不佳,尤其是安卓移动端。

上面这些只看文字不好理解,我直接上代码:

<div class="container">  <div class="content"></div>  <div class="filter">    Lorem ipsum dolor sit amet consectetur, adipisicing elit. Possimus voluptatem velit quod placeat?    Cupiditate,    corporis, et tempore laudantium consequatur labore distinctio nisi inventore totam vero cum est saepe quos    ad  </div></div>

我们定义了一个container元素div,子元素有content和filter两个div元素。

body {  margin: 0;  padding: 0;}.container {  width: 100%;  height: 100vh;  display: flex;  align-items: center;  justify-content: center;  background-color: aqua;}.content {  position: absolute;  bottom: 40%;  width: 300px;  height: 300px;  background-color: blueviolet;}.filter {  position: absolute;  bottom: 0;  width: 100%;  height: 50%;  font-size: 32px;  z-index: 20;}

以上元素,我们可以得到如下布局:

css中filter属性和backdrop-filter对比有什么区别

这时候,我们将filter元素改为

.filter {  position: absolute;  bottom: 0;  width: 100%;  height: 50%;  filter: blur(5px);  z-index: 20;  font-size: 32px;}

从代码看,我们添加了filter: blur(5px)。如下图展示效果,我们发现filter元素div和其中的文字内容,都被模糊化了。

css中filter属性和backdrop-filter对比有什么区别

但如果如下修改样式

.filter {  position: absolute;  bottom: 0;  width: 100%;  height: 50%;  backdrop-filter: blur(5px);  z-index: 20;  font-size: 32px;}

使用backdrop-filter: blur(5px)元素,则得到如下图排版

css中filter属性和backdrop-filter对比有什么区别

我们发现,只有filter元素DIV被模糊化,而子内容文字并没有受到任何影响。

.filter {  position: absolute;  bottom: 0;  width: 100%;  height: 50%;  background-color: chocolate;  backdrop-filter: blur(5px);  z-index: 20;  font-size: 32px;}

但是,如果按照以上代码,给filter元素设置了背景色background-color: chocolate,这时候,就几乎看不到模糊化的效果。

css中filter属性和backdrop-filter对比有什么区别

或者,我们把content元素DIV背景色去除,

.content {  position: absolute;  bottom: 40%;  width: 300px;  height: 300px;}

css中filter属性和backdrop-filter对比有什么区别

这就是为什么说,为了看到效果,必须使元素或其背景至少部分透明。

我们发现,backdrop-filter属性还只能在部分最新版浏览器上有效果,所以目前来看,此属性的兼容性较差。

css中filter属性和backdrop-filter对比有什么区别

以上就是关于“css中filter属性和backdrop-filter对比有什么区别”的内容,如果改文章对你有所帮助并觉得写得不错,劳请分享给你的好友一起学习新知识,若想了解更多相关知识内容,请多多关注编程网精选频道。

--结束END--

本文标题: css中filter属性和backdrop-filter对比有什么区别

本文链接: https://www.lsjlt.com/news/251146.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • css中filter属性和backdrop-filter对比有什么区别
    这篇文章主要为大家展示了css中filter属性和backdrop-filter对比有什么区别,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“css中filter属性和backdrop-filter...
    99+
    2023-06-08
  • jquery中find和filter有什么区别
    今天就跟大家聊聊有关jquery中find和filter有什么区别,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。jquery是什么jquery是一个简洁而快速的JavaScript库...
    99+
    2023-06-14
  • CSS中zoom属性和scale属性有什么区别
    CSS中zoom属性和scale属性有什么区别?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。zoom 属性语法:zoom:normal | <number...
    99+
    2023-06-09
  • CSS中padding-top和padding-left属性有什么区别
    本篇文章给大家分享的是有关CSS中padding-top和padding-left属性有什么区别,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。...
    99+
    2022-10-19
  • css中perspective属性和perspective()函数有什么区别
    本篇内容主要讲解“css中perspective属性和perspective()函数有什么区别”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“css中perspective属性和perspecti...
    99+
    2023-07-04
  • CSS中Display与Visibility属性有什么区别
    这篇文章给大家介绍CSS中Display与Visibility属性有什么区别,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。CSS中Display与Visibility属性的区别大多数人...
    99+
    2022-10-19
  • HTML中,src属性和href属性有什么区别?
    src属性和href属性是在HTML中常用的属性,用于指定网页中外部资源的引用。虽然它们都可以用来引用外部资源,但在使用和功能上却有着不同的用途。首先,src属性用于指定外部资源在网页中的嵌入方式,常用于引入图片、音频、视频等媒体文件,以及...
    99+
    2023-12-28
    html 区别 href src
  • CSS中Visibility和Display属性的区别是什么
    CSS中Visibility和Display属性的区别是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。CSS DIV中Visibility...
    99+
    2022-10-19
  • CSS中px和em属性的区别是什么
    这篇文章给大家介绍CSS中px和em属性的区别是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。详解px和em的特点和区别象素px是我们在定义CSS中经常用到的尺寸大小单位,而em在...
    99+
    2022-10-19
  • CSS中padding-bottom和padding-right属性的区别是什么
    今天就跟大家聊聊有关CSS中padding-bottom和padding-right属性的区别是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C...
    99+
    2022-10-19
  • CSS中padding-left和padding-left属性的区别是什么
    CSS中padding-left和padding-left属性的区别是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。CSS padding...
    99+
    2022-10-19
  • css中伪类和伪对象有什么区别
    这篇文章给大家分享的是有关css中伪类和伪对象有什么区别的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 伪类是用于向某些选择器添加特殊效果的;伪元素是...
    99+
    2022-10-19
  • mysql中mydumper和mysqldump对比使用有什么不区别
    小编给大家分享一下mysql中mydumper和mysqldump对比使用有什么不区别,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下...
    99+
    2022-10-18
  • 大数据存储系统对比中Ceph和Gluster有什么区别
    这篇文章给大家分享的是有关大数据存储系统对比中Ceph和Gluster有什么区别的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。  在分布式存储领域,Ceph和Gluster是两个很常见的开源软件平台,可以用来存储...
    99+
    2023-06-03
  • Python中私有属性下划线和双下划线的区别是什么
    今天小编给大家分享一下Python中私有属性下划线和双下划线的区别是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。在Py...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作