三行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 控制它们的密度。

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

相关推荐
海的诗篇_28 分钟前
前端开发面试题总结-vue2框架篇(四)
前端·css·面试·vue·html
用户4266705916929 分钟前
为什么说不可信的Wi-Fi不要随便连接?
前端
mortimer42 分钟前
当PySide6遇上ModelScope:一场关于 paraformer-zh is not registered 的调试旅程
人工智能·github·阿里巴巴
玺同学1 小时前
从卡顿到流畅:前端渲染性能深度解析与实战指南
前端·javascript·性能优化
小华同学ai1 小时前
GitHub 开源热搜!10.7k  star, MagicAnimate,让照片秒变动画短片!
github
我是谁谁1 小时前
一篇文章让你学透在Vue 3 中watch 和 watchEffect的区别
javascript
光影少年1 小时前
vuex中的辅助函数怎样使用
前端·javascript
teeeeeeemo1 小时前
JS数据类型检测方法总结
开发语言·前端·javascript·笔记
木木黄木木1 小时前
HTML5 火焰字体效果教程
前端·html·html5
云墨-款哥的博客1 小时前
失业学习-前端工程化-webpack基础
前端·学习·webpack