CSS
经常用 photoshop 的同学对这样一个透明方格的背景再熟悉不过了,也有的叫做“棋盘”效果,如下
2022-11-29-10-07-04.946124600.png
实现这种效果一定离不开渐变,这里介绍 3 种 CSS 绘制透明方格的小技巧

一、linear-gradient

linear-gradient可以说是最早实现这种效果的应用了,当然实现也最为巧妙,也最为复杂。原理是绘制两个直角三角形,然后拼接而成,如下
最小拼接单元其实是一个这样的图形,45deg方向上的一个渐变
为了便于观察,下面所有演示的颜色和尺寸都做了特殊处理,下同

  1. .bg{
  2. background-image: linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%)
  3. }

2022-11-29-10-07-05.209603500.png
平铺开来就是这样
2022-11-29-10-07-05.311377200.png
然后再绘制另一份一样的,错位拼接
2022-11-29-10-07-05.457192400.png
下面用一张动图来完整表现实现过程
CSS 实现透明方格的 3 种方式 - 图5
下面是完整代码

  1. .bg{
  2. width: 400px;
  3. height: 300px;
  4. background-image: linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%), linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%);
  5. background-size: 16px 16px;
  6. background-position: 0 0, 8px 8px;
  7. }

二、repeating-linear-gradient

repeating-linear-gradient也能实现“棋盘”效果,而且相比而言更容易理解一些,但是需要一点额外的小技巧
首先绘制一个水平条纹图案

  1. .bg{
  2. background-image: repeating-linear-gradient(#eee 0 8px, transparent 0 16px)
  3. }

2022-11-29-10-07-06.074295300.png
然后绘制一个垂直方向上的条纹

  1. .bg{
  2. background-image: repeating-linear-gradient(#eee 0 8px, transparent 0 16px), repeating-linear-gradient(90deg, #eee 0 8px, transparent 0 16px)
  3. }

2022-11-29-10-07-06.150102500.png
如果是灰色,看起来就是这样的
2022-11-29-10-07-06.262451900.png
条纹交错的地方是重叠的,像这种情况可以考虑加上背景混合模式,这里使用的是“滤色(screen)”,可以过滤掉黑色部分,如果是一个浅灰色,剩下的颜色就近乎是“白色”了。如下所示,“棋盘”效果就出来了(微信压缩太厉害)

  1. .bg{
  2. background-blend-mode: screen;
  3. }

CSS 实现透明方格的 3 种方式 - 图9
下面用一张动图来完整表现实现过程
2022-11-29-10-07-06.463395100.png
下面是完整代码

  1. .bg{
  2. width: 400px;
  3. height: 300px;
  4. background-image: repeating-linear-gradient(#eee 0 8px, transparent 0 16px), repeating-linear-gradient(90deg, #eee 0 8px, transparent 0 16px);
  5. background-blend-mode: screen;
  6. }

而且,这种方式可以实现任意倾角的效果,例如
2022-11-29-10-07-06.586282300.png
不过,混合模式的局限性也很多,目前在这种浅灰色看起来没什么问题,换一种颜色可能就不行了,例如这样的
2022-11-29-10-07-06.758750100.png
这就需要根据实际情况酌情使用了

三、conc-gradient

conc-gradient锥形渐变可以算的上是官方的解决方案了(MDN 上就有这个棋盘案例),不过兼容性略微差点
下面用一张动图来完整表现实现过程
CSS 实现透明方格的 3 种方式 - 图13
下面是完整代码

  1. .bg{
  2. width: 400px;
  3. height: 300px;
  4. background-image: conic-gradient(#eee 0 25%, transparent 0 50%, #eee 0 75%, transparent 0);
  5. background-size: 16px 16px;
  6. }

其实还可以用repeating-conic-gradient优化一下(原理是一样的,所以归为同一种方法),后面两个颜色是前面两个重复而来,所以可以只用两个颜色实现

  1. .bg{
  2. width: 400px;
  3. height: 300px;
  4. background-image: repeating-conic-gradient(#eee 0 25%, transparent 0 50%);
  5. background-size: 16px 16px;
  6. }

这应该算的上是纯 CSS 方案中最精简的了

四、实际上可能并不会用这些

虽然 CSS 渐变可以巧妙的实现这些图案,但平时工作中可能不会这么做,直接切图就好了,比如直接在 Figma 中绘制一个这样的 SVG
2022-11-29-10-07-06.968475000.png
然后直接用这张图就好了

  1. .bg{
  2. width: 400px;
  3. height: 300px;
  4. background-image: url('xxx.svg');
  5. background-size: 16px 16px;
  6. }

10 秒不到就完成了这样的“棋盘”效果,简单快捷,没有兼容性问题。
是不是 CSS 渐变就是鸡肋?
当然不是!CSS 渐变绘制出的是动态的,可以动态调整颜色、尺寸、或者形状,这些都不是静态图片能够实现的。比如这样的,恐怕就需要存多份图片了,但对于渐变来说,改一个颜色值就行

  1. .bg{
  2. width: 400px;
  3. height: 300px;
  4. background-image: repeating-conic-gradient(var(--color) 0 25%, transparent 0 50%);
  5. background-size: 16px 16px;
  6. }
  7. .bg1{
  8. --color1: gray;
  9. }
  10. .bg2{
  11. --color1: yellow;
  12. }
  13. .bg1{
  14. --color1: blue;
  15. }

2022-11-29-10-07-07.081106600.png
更为重要的一点是,学习掌握渐变对提升自身 CSS 水平有非常大的帮助。不过,也需要根据实际情况,如果不需要动态改变一些样式的话,SVG 图片也是一种好方法,但一定不要停止思考🤔。