三行CSS代码把网页像素化

作者:程序员成长指北

原文:mp.weixin.qq.com/s/O9rKeH2RV...

最近在浏览网页时,Element-plus 官网那极具 "fashion" 感的页面效果深深吸引了我。录制了一个效果,大家可以感受一下。

顶部导航栏区域在页面滚动时,经过该区域的内容瞬间变成 "像素画" 的神奇效果,简直让人眼前一亮。

创意和视觉效果的实现往往能带来意想不到的惊喜,有些效果很惊艳但是实现原理往往可能朴实无华!

好奇心驱使下,我深入研究,并用 CSS 成功复刻了这一效果,下面就为大家详细剖析其中的奥秘。先看一下实现的效果:

通过下面这段代码,我们可以实现像素画效果与正常显示效果的切换,还能对像素画的渐变、大小、模糊程度进行调整:

xml 复制代码
<template>
 <div class="wrap">
<!-- 控制像素化效果开关 -->
<el-switch
      v-model="isPixel"
      active-text="像素化"
      inactive-text="正常"
  ></el-switch>

<!-- 控制项统一结构,便于维护 -->
<div class="control">
    <label class="label">渐变:</label>
    <el-slider v-model="gradient" :max="10" :disabled="!isPixel" />
</div>
<div class="control">
    <label class="label">大小:</label>
    <el-slider v-model="size" :max="10" :disabled="!isPixel" />
</div>
<div class="control">
    <label class="label">模糊:</label>
    <el-slider v-model="drop" :max="10" :disabled="!isPixel" />
</div>

<!-- 图片区域 -->
<div class="content">
    <div class="pixel" :style="pixelStyle"></div>
    <img class="image" src="../../assets/image/1750313558402.jpg" alt="像素图" />
</div>
</div>
</template>

<script>
export default {
name: 'PixelStyle',
  data() {
    return {
      isPixel: false,  // 是否启用像素化
      gradient: 1,     // 渐变范围
      size: 4,         // 像素块大小
      drop: 4          // 模糊强度
    };
  },
computed: {
    pixelStyle() {
      // 只在启用像素化时应用样式
      returnthis.isPixel
        ? {
            backgroundImage: `radial-gradient(transparent ${this.gradient}px, #fff ${this.gradient}px)`,
            backgroundSize: `${this.size}px ${this.size}px`,
            backdropFilter: `blur(${this.drop}px)`,
            backgroundRepeat: 'repeat'
          }
        : {};
    }
  }
};
</script>

<style scoped>
.wrap {
width: 500px;
margin: 0 auto;
padding: 20px;
border: 1px solid #ddd;
box-sizing: border-box;
color: #333;
margin-top: 20px;
}

/* 控制行结构统一处理 */
.control {
margin-top: 10px;
}

.label {
width: 80px;
font-size: 14px;
color: #555;
}

/* 内容区域 */
.content {
position: relative;
width: 100%;
margin-top: 20px;
padding: 30px;
overflow: hidden;
}

.pixel {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 9;
pointer-events: none;
}

/* 图片样式独立控制 */
.image {
width: 100%;
height: auto;
object-fit: cover;
display: block;
}
</style>

原理分析

这个像素化效果的关键是:用一层带有模糊和网格背景的遮罩,覆盖在图片上方。

遮罩通过 backdrop-filter: blur() 让图片变得模糊,再用 radial-gradient 制作出一格格"透明+白色"的小圆点背景,配合 background-size 控制它们的密度。

最终,人眼看到的是:部分图片清晰,部分被白色圆点+模糊叠加,就像一个"低分辨率"的像素画效果。

相关推荐
我血条子呢几秒前
【CSS】类似渐变色弯曲border
前端·css
DanyHope几秒前
LeetCode 两数之和:从 O (n²) 到 O (n),空间换时间的经典实践
前端·javascript·算法·leetcode·职场和发展
hgz07102 分钟前
企业级多项目部署与Tomcat运维实战
前端·firefox
zhoumeina992 分钟前
懒加载图片
前端·javascript·vue.js
用户1887871069844 分钟前
SVG描边 - CSS3实现动画绘制矢量图
前端
码上行走4 分钟前
【实战】Flex布局-上下自适应
前端
DarkLONGLOVE4 分钟前
Vue的“小外挂”:玩转自定义指令
前端·javascript·vue.js
用户1887871069845 分钟前
前端实现页面截图及截图内容包含跨域图片时的处理
javascript
ccino .5 分钟前
pdf-xss文件制作过程
前端·pdf·xss
晚烛6 分钟前
实战前瞻:构建高韧性、可扩展的 Flutter + OpenHarmony 智慧政务服务平台
javascript·flutter·政务