我目前正在努力爲我的網站設置圖像背景,加載速度不夠快。我已經使用了數據網址圖像,甚至是視覺化的圖像,但是由於背景圖像仍然非常大,因此在加載頁面時花費很長時間。是否有可能用CSS創建一個紋理背景顏色,如下圖所示?這裏是一個EXAMPLECSS:創建紋理背景
我嘗試它,一直無法匹配這樣的:
我目前正在努力爲我的網站設置圖像背景,加載速度不夠快。我已經使用了數據網址圖像,甚至是視覺化的圖像,但是由於背景圖像仍然非常大,因此在加載頁面時花費很長時間。是否有可能用CSS創建一個紋理背景顏色,如下圖所示?這裏是一個EXAMPLECSS:創建紋理背景
我嘗試它,一直無法匹配這樣的:
與最新的CSS3技術,它可以創建紋理背景。看看這個:http://lea.verou.me/css3patterns/#
但它仍然限制了很多方面。而瀏覽器的支持也沒那麼好。
你最好的選擇是使用小紋理圖像,並重復該背景。你可以得到一些不錯的準備在這裏使用的紋理圖像:
也http://patternify.com – albert 2012-08-05 04:53:00
謝謝!就是我在找的東西! – CodingWonders90 2012-08-05 05:22:49
@albert,Nod 32封鎖** patternify.com **並表示網頁位於具有潛在危險內容的網站列表中。 – stom 2016-09-15 09:36:27
你應該嘗試如果可能的話切片圖像劃分成較小的一塊,其可以重複。我已將該圖片切分爲101x101px圖片。
CSS:
body{
background-image: url(SO_texture_bg.jpg);
background-repeat:repeat;
}
但在某些情況下,我們將無法將圖像切到一個較小的一個。在這種情況下,我會使用整個圖像。但你也可以使用像Mustafa Kamal提到的那樣的CSS3方法。
祝你好運。
只是好奇,是否有你選擇101像素的原因?這看起來像一個非標準尺寸,我想知道是否有這個原因。 – 2017-04-04 19:36:29
如果您搜索圖像base-64轉換器,您可以將一些小圖像紋理文件作爲代碼嵌入到@import url('')
代碼部分。它看起來像很多代碼;但至少所有數據現在都存儲在本地 - 而不必調用單獨的資源來加載圖像。
實例鏈接:http://www.base64-image.de/
當我從我自己的PNG格式的簡單圖標的庫存文件,並將其轉換爲基於64位,它看起來像這樣在我的CSS:
url('')
用你的紋理圖像,你會想要採用類似的過程。
使用圖像編輯器剪切出背景的一部分,然後應用CSS的background-repeat屬性使小圖像填充使用它的區域。
在某些情況下,background-repeat會在圖像重複的位置創建接縫。一種解決方案是使用圖像編輯器,如下所示:從背景圖像開始,複製圖像,從左向右翻轉副本(鏡像,不旋轉),並將其粘貼到原始重疊1像素的右邊緣。剪裁從組合圖像的右邊緣移除1個像素。現在重複垂直:複製組合圖像,從上到下翻轉副本,將其粘貼到組合的重疊一個像素的底部。裁剪從底部移除1個像素。由此產生的圖像應該是無縫的。
使用平鋪背景圖像,這是獲取詳細信息的唯一方法。絕對*不要*使用'data:'URI。它看起來像是特定的圖案可以安全地重複在一個非常小的尺寸,如果你只是改變紋理一點是可以修復的。 – Ryan 2012-08-05 04:46:29
您可以使用SVG和CSS(https://stackoverflow.com/a/49108254)以大約400個字節輕鬆實現此功能。作爲獎勵,你可以添加一個漸變幾乎沒有額外的成本。 – 2018-03-05 10:43:20