CSS 实现透明方格的 3 种方式

大厂技术  高级前端  Node进阶

点击上方 程序员成长指北,关注公众号

回复1,加入高级Node交流群

经常用 photoshop 的同学对这样一个透明方格的背景再熟悉不过了,也有的叫做“棋盘”效果,如下

17eece4e92ed3f6556074a5f1ead998f.png
image-20220225111710246

实现这种效果一定离不开渐变,本文介绍 3 种 CSS 绘制透明方格的小技巧

一、linear-gradient

linear-gradient可以说是最早实现这种效果的应用了,当然实现也最为巧妙,也最为复杂。原理是绘制两个直角三角形,然后拼接而成,如下

最小拼接单元其实是一个这样的图形,45deg方向上的一个渐变

为了便于观察,下面所有演示的颜色和尺寸都做了特殊处理,下同

.bg{
  background-image: linear-gradient(45deg, #eee 25%, transparent 25%, transparent 75%, #eee 75%)
}
20b122898d8218ba7602c63576da7ae2.png
image-20220225134336176

平铺开来就是这样

874af35a6abfbdda48e51d2695154324.png
image-20220225135117202

然后再绘制另一份一样的,错位拼接

a15e011385858888a098ef4950674069.png
image-20220225135320970

下面用一张动图来完整表现实现过程

e32a921940d8865f3eb6f2562a4208ff.gif
Kapture 2022-02-25 at 13.59.10

下面是完整代码

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

二、repeating-linear-gradient

repeating-linear-gradient也能实现“棋盘”效果,而且相比而言更容易理解一些,但是需要一点额外的小技巧

首先绘制一个水平条纹图案

.bg{
  background-image: repeating-linear-gradient(#eee 0 8px, transparent 0 16px)
}
07617be7b366d78b3922163b89cc0262.png
image-20220225142228336

然后绘制一个垂直方向上的条纹

.bg{
  background-image: repeating-linear-gradient(#eee 0 8px, transparent 0 16px), repeating-linear-gradient(90deg, #eee 0 8px, transparent 0 16px)
}
3755ffb1f488ea945dfaf798fb52a341.png
image-20220225144412154

如果是灰色,看起来就是这样的

113548414c95ce91cdeb2da12dc60a34.png
image-20220225142640668

条纹交错的地方是重叠的,像这种情况可以考虑加上背景混合模式(关于混合模式,可以参考张鑫旭老师的这篇文章:深入理解CSS mix-blend-mode滤色screen混合模式[1]),这里使用的是“滤色(screen)”,可以过滤掉黑色部分,如果是一个浅灰色,剩下的颜色就近乎是“白色”了。如下所示,“棋盘”效果就出来了(微信压缩太厉害)

.bg{
  background-blend-mode: screen;
}
83aa6bb9e1fff5a97674ba99ddf3d580.gif
Kapture 2022-02-25 at 14.47.37

下面用一张动图来完整表现实现过程

eaa45acbf64399f814b3a8216269d20b.png

Kapture 2022-02-25 at 14.31.03

下面是完整代码

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

而且,这种方式可以实现任意倾角的效果,例如

3d7beae56633b2ad8e2c593603e03a23.png
image-20220225152031677

不过,混合模式的局限性也很多,目前在这种浅灰色看起来没什么问题,换一种颜色可能就不行了,例如这样的

5d9a5eb6fd1344d73517425135c17360.png
image-20220225145203162

这就需要根据实际情况酌情使用了

三、conc-gradient

conc-gradient锥形渐变可以算的上是官方的解决方案了(MDN 上就有这个棋盘案例),不过兼容性略微差点

下面用一张动图来完整表现实现过程

62cdccf859208cde9d51fc0c23c7bd73.gif
Kapture 2022-02-25 at 15.30.13

下面是完整代码

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

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

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

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

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

虽然 CSS 渐变可以巧妙的实现这些图案,但平时工作中可能不会这么做,直接切图就好了,比如直接在 Figma 中绘制一个这样的 SVG

43c342051b42ce576b36d3025b864297.png
image-20220225154224138

然后直接用这张图就好了

.bg{
    width: 400px;
    height: 300px;
    background-image: url('xxx.svg');
   background-size: 16px 16px;
}

10 秒不到就完成了这样的“棋盘”效果,简单快捷,没有兼容性问题。

是不是 CSS 渐变就是鸡肋?

当然不是!CSS 渐变绘制出的是动态的,你可以动态调整颜色、尺寸、或者形状,这些都不是静态图片能够实现的。比如这样的,恐怕就需要存多份图片了,但对于渐变来说,改一个颜色值就行

.bg{
    width: 400px;
    height: 300px;
    background-image: repeating-conic-gradient(var(--color) 0 25%, transparent 0 50%);
   background-size: 16px 16px;
}
.bg1{
  --color1: gray;
}
.bg2{
  --color1: yellow;
}
.bg1{
  --color1: blue;
}
08a44624982491772c57ae1fca355f09.png
image-20220225155717693

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

最后,如果觉得还不错,对你有帮助的话,欢迎点赞、收藏、转发❤❤❤

Node 社群


我组建了一个氛围特别好的 Node.js 社群,里面有很多 Node.js小伙伴,如果你对Node.js学习感兴趣的话(后续有计划也可以),我们可以一起进行Node.js相关的交流、学习、共建。下方加 考拉 好友回复「Node」即可。

如果你觉得这篇内容对你有帮助,我想请你帮我2个小忙:

1. 点个「在看」,让更多人也能看到这篇文章2. 订阅官方博客 www.inode.club 让我们一起成长

点赞和在看就是最大的支持❤️

参考资料

[1]

深入理解CSS mix-blend-mode滤色screen混合模式: https://www.zhangxinxu.com/wordpress/2019/05/css-mix-blend-mode-screen/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值