纯CSS 实现格子背景(国际象棋棋盘)


theme: smartblue

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第4天,点击查看活动详情

本文简介

点赞 + 收藏 + 关注 = 学会了

这次会使用css画出一个格子背景。并且一步步分析如何实现~

01.png

思路

直接给答案:通过2个相等的直角三角形拼接,形成一个正方形。

三角形可以使用 background-image 的渐变来实现。

css html, body { margin: 0; width: 100%; height: 100%; } body { background-image: linear-gradient(45deg, #000 25%, transparent 0); }

02.png

此时出来的效果如上图所示。

做一个45度的线性渐变,第一个颜色是#000(黑色),占整个背景贴片的25%,其余部分都是红色。

在上面的基础上,用 background-size 来控制背景贴片的大小。

css body { background-image: linear-gradient(45deg, #000 25%, transparent 0); background-size: 200px 200px; }

03.png

开始有点想法了吗?

此时如果我们再画多一个反过来的黑色的直角三角形,拼在一起不就成了正方形了吗?

反过来的三角形怎么画呢?我尝试将黑色从 25% 改成 75%,会得到以下效果

css body { background-image: linear-gradient(45deg, #000 75%, transparent 0); background-size: 200px 200px; }

04.png

可以看到红色的三角形就是原本黑色三角形反过来的样子。

把上图的“白色三角形”变成黑色,原本的黑色三角形(25%)继续保留。

于是我又加多层渐变~

css body { background-image: linear-gradient(45deg, #000 25%, transparent 0), linear-gradient(45deg, transparent 75%, #000 0); background-size: 200px 200px; }

05.png

简化一下代码:

css body { background-image: linear-gradient(45deg, #000 25%, transparent 0, transparent 75%, #000 0); background-size: 200px 200px; }

最后再做多一层上面的效果,然后移动一下其中一层的位置,就可以合并成一个黑色正方形。

css body { background-image: linear-gradient(45deg, #000 25%, transparent 0, transparent 75%, #000 0), linear-gradient(45deg, #000 25%, transparent 0, transparent 75%, #000 0); background-position: 0 0, 100px 100px; background-size: 200px 200px; }

06.png

大功告成。

最后需要提醒的是,在本例中 background-position 第二个渐变的位移是 background-size 的一半,这样就能实现这种格子背景了~

完整代码

```html ```

这是做成背景的完整代码。

推荐阅读

👍《CSS里的ch到底是什么东西?》

👍《给console来的样式》

👍《如何用 CSS 选择符杀死队友》

👍《这18个网站能让你的页面背景炫酷起来》

👍《纯CSS:动态渐变背景【一分钟学会】》

👍《纯css实现117个Loading效果》

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值