【CSS】背景模糊,不模糊主体文字

问题

  • 背景模糊,不模糊文本

效果图

t1

t2

t3



实现思路

  1. 自定义css变量存储图片地址,方便后期更改
  2. 使用伪元素实现背景模糊达到不遮挡主体文本
  3. transform: scale(1.5)吧图片放大1.5倍,避免设置背景模糊出现白边。
  4. overflow: hidden 超出隐藏,避免背景放大出现白边、撑出滚动条。
  5. background-position: 50%背景中间为起始位置
  6. background-size: cover取背景中间
  7. 使用 filter: blur(20px) brightness(50%)模糊背景+降低背景亮度
    • blur(20px) 模糊20px
    • brightness(50%) 亮度降低50% ,如果不降低亮度,会导致太亮而影响主体文字,如下图
  8. 降低亮度效果图

代码实现

html 复制代码
<div class="music-box" style="width: 300px; height: 600px"></div>
 <style>
:root {
  /* 自定义变量 */
  --music-bg: url("/testImg/photo0000-1246.jpg");
}

.music-box {
  position: relative;
}

.music-box::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  overflow: hidden;
  filter: blur(20px) brightness(50%);
  background-size: cover;
  /* 使用自定义变量 --music-bg*/
  background-image: var(--music-bg);
  background-position: 50%;
  transform: scale(1.5);
}
</style>

更改图片地址

js 复制代码
document.body.style.setProperty('--music-bg', `url(/myimg.jpeg)`)
相关推荐
luback5 小时前
前端把页面用PDF导出
前端·pdf·reactjs·html2canvas
豹哥学前端5 小时前
10分钟彻底搞懂 window 对象、全局环境与 JS 引擎
前端·面试
晴殇i5 小时前
前端混合状态管理架构:Redux Toolkit + Zustand 协同设计、规范落地与性能优化
前端·openai
OpenTiny社区5 小时前
GenUI SDK 生成式UI:六大开发特性详解,适配多种业务场景
前端·github·ai编程
大家的林语冰5 小时前
TS 登顶第一语言;JS 最新 Temporal 时间减屎;Node 爆发反 AI 运动;CSS 将支持图片亮暗切换《前端周刊》
前端·javascript·css
Hilaku5 小时前
OpenClaw 为什么突然不火了?
前端·javascript·程序员
精益数智工坊5 小时前
物料管理是什么?物料管理的具体工作有哪些?
大数据·前端·数据库·人工智能·精益工程
岩岩很哇塞!6 小时前
【vue实现模仿探探卡片滑动切换效果】
前端·javascript·vue.js
无我Code6 小时前
全套开源:一款云端服务+本地设备计算的文生图应用
前端·人工智能·后端
用户69371750013847 小时前
实测可用|小米 MiMo 百万亿 Token 免费领,开发者速冲
前端·后端·ai编程