CSS 滤镜(filter)

CSS 滤镜(filter)是 CSS3 推出的一组"即时图形后期"工具。

它不需要 Photoshop,也不需要 Canvas,只要一行声明就能把亮度、对比度、模糊、色相偏移等视觉效果实时渲染到任何元素 上------图片、文字、视频、背景图,甚至整个模块都可以一次性处理。

下面带你从零开始认识这套"前端版美图秀秀"。


一、最简记忆:滤镜 = 函数链

css 复制代码
filter: <函数-1>(参数) <函数-2>(参数) ... ;
  • 顺序从左到右依次执行,类似管道符。
  • 每个函数都有明确区间,超出即 clamp(被裁剪)。
  • 可以写任意多个,空格分隔;也可以只写一个。

二、10 个原生函数速查表

函数 作用 默认值 常见玩法
blur(px) 高斯模糊 0 毛玻璃背景、loading 遮罩
brightness(number) 线性亮度 1 0.6 夜间模式,1.4 高光
contrast(number) 对比度 1 1.5 让黑白更分明
grayscale(number) 去色 0 1 彻底灰度,0.5 淡彩
sepia(number) 复古棕褐 0 1 老照片,0.3 暖色打底
saturate(number) 饱和度 1 0 灰度,2 鲜艳
hue-rotate(deg) 色相旋转 0deg 180deg 反色,90deg 换季节
invert(number) 负片 0 1 完全反色,0.9 暗黑模式
opacity(number) 透明度 1 与 CSS opacity 差异见注①
drop-shadow() 真实投影 支持半透明 PNG 的"镂空"阴影

注①:filter:opacity()创建独立层叠上下文 ,而 opacity 属性不会;前者还能被硬件加速。


三、组合实战 4 例

  1. 一键暗黑
css 复制代码
.dark {
  filter: invert(1) hue-rotate(180deg) brightness(1.1);
}

原理:先反色,再把色相转半圈,最后略提亮,文字与图片一起"变黑"。

  1. 毛玻璃遮罩
css 复制代码
.mask {
  backdrop-filter: blur(10px) saturate(1.2);
  background: rgba(255,255,255,0.4);
}

backdrop-filter 只模糊背后内容,自身背景保持半透明,iOS 风导航栏标配。

  1. 图片 hover 高亮
css 复制代码
img {
  transition: filter .3s;
}
img:hover {
  filter: brightness(1.15) saturate(1.25);
}

鼠标移入瞬间"亮 + 艳",移出平滑回落。

  1. 文字故障风
css 复制代码
.glitch {
  filter: contrast(2) hue-rotate(90deg);
  text-shadow: 2px 0 #0ff, -2px 0 #f0f;
}

高对比 + 色相偏移 + 双色阴影,赛博朋克感拉满。


四、性能与兼容

  1. 硬件加速:现代浏览器会把 filter 丢给 GPU,通常比 Canvas 快,但:

    • 同时挂 5+ 个滤镜、大面积模糊(>30 px)或 4K 视频仍可能掉帧。
    • 移动端尽量 will-change:filter 提前声明,动画结束及时清除。
  2. 兼容性(2025 年 5 月):

    • 桌面:Chrome 53+、Edge 79+、Firefox 55+、Safari 14+ 全支持。
    • 移动端:iOS Safari 14+、Android Chrome 90+ 全覆盖。
    • 唯一老梗:IE 全系不支持,可优雅降级(无滤镜即原图)。
  3. 前缀:如今无需 -webkit-,但老设备(Android 7)仍建议:

css 复制代码
-webkit-filter: blur(5px);
filter: blur(5px);

五、常见坑点

  • filter 会让元素生成包含块 (contain: paint),内部 position:fixed 会"降级"为相对于该元素。
  • drop-shadowbox-shadow 差异:前者沿不透明像素边缘生成,适合 PNG 图标;后者永远矩形。
  • 滤镜不能 作用于:
    -- 父元素对子元素的背景穿透(background-filter 才行)
    -- 部分表单控件(如 <video> 的 controls 条,需关闭原生控件再自定义)

六、一句话总结

CSS filter 把"后期调色"从设计软件搬到了浏览器,一行代码即可让网页拥有场景化氛围

白天/黑夜、节日换肤、图片灰度、视频负片、毛玻璃导航......

掌握这 10 个函数,你就拥有了不刷新页面、不增加图片体积的即时视觉魔法。

相关推荐
时雨__6 小时前
uniapp转鸿蒙app内部测试发布过程——踩坑记录
前端·harmonyos
去伪存真6 小时前
Android手机不支持文字转语音window.speechSynthesis API,怎么办?
前端
三年三月7 小时前
自建HTTPS证书
前端·javascript
木易士心7 小时前
如何优化v-if和v-for的性能?
前端·javascript
三年三月7 小时前
浏览器地址栏回车 vs 点击刷新按钮的缓存行为差异分析
前端·javascript
码农刚子7 小时前
ASP.NET Core Blazor 核心功能一:Blazor依赖注入与状态管理指南
前端·后端
胖虎2657 小时前
基于Vue3+xgplayer 移动端直播解决方案
前端
用户4099322502127 小时前
Vue 3模板如何通过编译三阶段实现从声明式语法到高效渲染的跨越
前端·ai编程·trae
小左OvO7 小时前
基于百度地图JSAPI Three的城市公交客流可视化(二)——区域客流
前端·javascript·vue.js