想必大家都知道網頁加載的過程,從開始請求,到加載頁面,開始解析和顯示網頁,遇到圖片就再次向服務器發送請求,加載圖片。如果圖片很多的話,就會產生大量的http請求,從而影響頁面的加載速度。所以現在有一種做法是將多張圖片合並到一起,這樣在打開頁面的時候只需要一次http請求就可以加載多張圖片,然后通過設置圖片的背景偏移量來正確的顯示。現在我們可以將圖片轉成base64編碼,然后直接寫在html頁面或者css里面,這樣在加載頁面或者css的時候就可以直接將圖片加載過去,這樣也省去了設置圖片背景偏移量帶來的瀏覽器兼容性問題。
1、在html中img標簽中顯示base64編碼的圖片
下面我們來看一下如何顯示一張圖片:
<img src=" wAAACwAAAAADwAPAAACIISPeQHsrZ5ModrLlN48CXF8m2iQ3YmmKqVlRtW4ML wWACH+H09wdGltaXplZCBieSBVbGVhZCBTbWFydFNhdmVyIQAAOw==" alt="Base64 encoded image" width="150" height="150"/>
顯示如下圖:
2、將base64編碼的圖片嵌入到css中
在css里面的實現如下:
.main { width: 600px; height: 300px; background-image:url(); }
下面來說一下如何在C#中將圖片轉化成base64字符串,由於比較簡單,這里只寫一些主要的實現方法,大家可以自己畫界面,做成一個工具。這里我新建一個控制台的項目。編寫如下代碼:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.IO; namespace ConvertImgToBase64 { class Program { static void Main(string[] args) { FileInfo file = new FileInfo("1.png"); var stream = file.OpenRead(); byte[] buffer = new byte[file.Length]; //讀取圖片字節流 stream.Read(buffer, 0, Convert.ToInt32(file.Length)); //將base64字符串保存到base64.txt文件中 StreamWriter sw = new StreamWriter("base64.txt",false, Encoding.UTF8); //將字節流轉化成base64字符串 sw.Write(Convert.ToBase64String(buffer)); sw.Close(); Console.WriteLine("Convert successful!"); Console.Read(); } } }
然后我們打開base64.txt文件,講里面的代碼復制到img標簽里面,代碼如下:

<!DOCTYPE html> <html> <head> <title>Before | After</title> <meta charset="UTF-8"> </head> <style> .main { width: 200px; height: 100px; background-image:url(); } </style> <body> <div class="main"></div> <img src="" alt="Base64 encoded image" /> </body> </html>
顯示結果如圖:
我們可以看到,上面那么小的一張圖片,轉換成base64字符串后,會變成很長的一串字符串,如果我們將所有的圖片都轉換的話,雖然是網頁打開速度會略有提升,但是代碼會變的臃腫,難以維護。所以,我們可以將一些很小的圖片轉換成base64編碼,嵌入到css文件中,如小的圖標。
作者:雲霏霏
QQ交流群:243633526
博客地址:http://www.cnblogs.com/yunfeifei/
聲明:本博客原創文字只代表本人工作中在某一時間內總結的觀點或結論,與本人所在單位沒有直接利益關系。非商業,未授權,貼子請以現狀保留,轉載時必須保留此段聲明,且在文章頁面明顯位置給出原文連接。
如果大家感覺我的博文對大家有幫助,請推薦支持一把,給我寫作的動力。