本文介绍: 是不是在日常开发中经常遇到实现网格需求网格通常对网页展示元素能起到很好的定位对齐作用这里介绍如何通过 CSS 来实现这个需求使用背景图这里我们背景图使用 SVG 来创建,首先,创建绘出一个正方形填充白色;然后通过矩形实现垂直和水平的线条,进而分别对它们进行定位居中。<svgxmlns=’http://www.w3.org/2000/svgwidth=’40’hei

是不是在日常开发中经常遇到实现网格需求,网格通常对网页中展示的元素能起到很好的定位对齐作用。

这里介绍如何通过 CSS 来实现这个需求

使用背景图

这里我们背景图使用 SVG 来创建,首先,创建绘出一个正方形填充白色;然后通过矩形实现垂直和水平的线条,进而分别对它们进行定位居中

<svg xmlns='http://www.w3.org/2000/svgwidth='40' height='40'>
  &lt;rect width='40' height='40' fill='#fff'&gt;</rect&gt;
  <rect x='50%' width='1' height='100%' fill='rgb(203 213 225)'&gt;</rect&gt;
  <rect y='50%' width='100%' height='1' fill='rgb(203 213 225)'&gt;</rect&gt;
</svg&gt;

效果如下

有了背景图片,我们对给定区域设置背景

.grid {
  background-imageurl('/path/to/grid.svg');
}

如果要避免加载额外资源,我们也可以通过图片二进制数据方式嵌入

.grid {
  background-imageurl("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svgwidth='40' height='40'%3E%3Crect width='40' height='40' fill='%23fff' /%3E%3Crect x='50%' width='1' height='100%' fill='rgb(203 213 225)' /%3E%3Crect y='50%' width='100%' height='1' fill='rgb(203 213 225)' /%3E%3C/svg%3E%0A");
}

默认情况下,背景图像会在垂直和水平方向上重复,这样实现的网格是40个像素。我们也可以通过 background-size 属性自定义背景图尺寸

57b1dee0c8cd1b02bf0a117aacc6ae0d.png

.grid {
  background-size: 20px;
}

35924ec7a5630b9e6dcaf7211a4a21dc.png

使用线性渐变

另一种使用 CSS 创建网格背景方式通过 linear-gradient() 函数实现的。

首先选择要为其添加网格背景元素,并设置 background-image 属性然后,使用 linear-gradient() 函数 指定两种颜色,这两种颜色可以是相似相同的,它们之间线条粗细宽度相同透明部分分隔开来。

.grid {
  background-imagelinear-gradient(to rightgray 1pxtransparent 1px);
}

这里1px 代表网格的线条宽度,你也可以设置成你想要的宽度

如果要实现水平线条,只需要to right 改为 to botton 。而网格实现既需要横向的线条,也需要纵向的线条。

.grid {
  background-image:
    linear-gradient(to right, gray 1pxtransparent 1px),
    linear-gradient(to bottom, gray 1pxtransparent 1px);
}

最终的样式

.grid {
  height: 200px;
  background-image:
      linear-gradient(to rightrgb(203 213 225) 1px, transparent 1px),
      linear-gradient(to bottomrgb(203 213 225) 1px, transparent 1px);
  background-size: 20px 20px;
  background-positioncenter center;
}

4e180d5564e8d6beb394d1b3f6e03b7a.png

网状点阵背景

相同原理,我们来实现一个网状点阵背景,这里需要用到 radial-gradient 函数创建圆形填充背景色

.grid {
  height: 200px;
  background-image: radial-gradient(circlergb(203 213 225) 2px, #fff 2px);
  background-size: 20px 20px;
  background-positioncentecenter;
}

60e27fd41e3c4aa0c000610851248dd0.png

拓展

另外关注一下这种模拟透明背景样式的实现原理:

.grid {
  height: 200px;
  background-image:
    linear-gradient(45deg, #8d8b8b 25%, transparent 0),
    linear-gradient(-45deg, #8d8b8b 25%, transparent 0),
    linear-gradient(45deg, transparent 75%, #8d8b8b 0),
    linear-gradient(-45deg, transparent 75%, #8d8b8b 0);
  background-position: 0 0, 0 10px, 10px -10px, -10px 0;
  background-size: 20px 20px;
}

028777b55a4a027a18cecc646a7bf333.png

原文地址:https://blog.csdn.net/u013919171/article/details/134689970

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_45878.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注