2012-08-05 120 views
41

我目前正在努力为我的网站设置图像背景,加载速度不够快。我已经使用了数据网址图像,甚至是视觉化的图像,但是由于背景图像仍然非常大,因此在加载页面时花费很长时间。是否有可能用CSS创建一个纹理背景颜色,如下图所示?这里是一个EXAMPLECSS:创建纹理背景

我尝试它,一直无法匹配这样的:

enter image description here

+0

使用平铺背景图像,这是获取详细信息的唯一方法。绝对*不要*使用'data:'URI。它看起来像是特定的图案可以安全地重复在一个非常小的尺寸,如果你只是改变纹理一点是可以修复的。 – Ryan 2012-08-05 04:46:29

+0

您可以使用SVG和CSS(https://stackoverflow.com/a/49108254)以大约400个字节轻松实现此功能。作为奖励,你可以添加一个渐变几乎没有额外的成本。 – 2018-03-05 10:43:20

回答

67

与最新的CSS3技术,它可以创建纹理背景。看看这个:http://lea.verou.me/css3patterns/#

但它仍然限制了很多方面。而浏览器的支持也没那么好。

你最好的选择是使用小纹理图像,并重复该背景。你可以得到一些不错的准备在这里使用的纹理图像:

http://subtlepatterns.com

+8

也http://patternify.com – albert 2012-08-05 04:53:00

+1

谢谢!就是我在找的东西! – CodingWonders90 2012-08-05 05:22:49

+1

@albert,Nod 32封锁** patternify.com **并表示网页位于具有潜在危险内容的网站列表中。 – stom 2016-09-15 09:36:27

17

你应该尝试如果可能的话切片图像划分成较小的一块,其可以重复。我已将该图片切分为101x101px图片。

BG Tile

CSS:

body{ 
    background-image: url(SO_texture_bg.jpg); 
    background-repeat:repeat; 
} 

但在某些情况下,我们将无法将图像切到一个较小的一个。在这种情况下,我会使用整个图像。但你也可以使用像Mustafa Kamal提到的那样的CSS3方法。

祝你好运。

+0

只是好奇,是否有你选择101像素的原因?这看起来像一个非标准尺寸,我想知道是否有这个原因。 – 2017-04-04 19:36:29

1

如果您搜索图像base-64转换器,您可以将一些小图像纹理文件作为代码嵌入到@import url('')代码部分。它看起来像很多代码;但至少所有数据现在都存储在本地 - 而不必调用单独的资源来加载图像。

实例链接http://www.base64-image.de/

当我从我自己的PNG格式的简单图标的库存文件,并将其转换为基于64位,它看起来像这样在我的CSS:

url('') 

用你的纹理图像,你会想要采用类似的过程。

1

使用图像编辑器剪切出背景的一部分,然后应用CSS的background-repeat属性使小图像填充使用它的区域。

在某些情况下,background-repeat会在图像重复的位置创建接缝。一种解决方案是使用图像编辑器,如下所示:从背景图像开始,复制图像,从左向右翻转副本(镜像,不旋转),并将其粘贴到原始重叠1像素的右边缘。剪裁从组合图像的右边缘移除1个像素。现在重复垂直:复制组合图像,从上到下翻转副本,将其粘贴到组合的重叠一个像素的底部。裁剪从底部移除1个像素。由此产生的图像应该是无缝的。