想必大家都知道网页加载的过程,从开始请求,到加载页面,开始解析和显示网页,遇到图片就再次向服务器发送请求,加载图片。如果图片很多的话,就会产生大量的http请求,从而影响页面的加载速度。所以现在有一种做法是将多张图片合并到一起,这样在打开页面的时候只需要一次http请求就可以加载多张图片,然后通过设置图片的背景偏移量来正确的显示。现在我们可以将图片转成base64编码,然后直接写在html页面或者css里面,这样在加载页面或者css的时候就可以直接将图片加载过去,这样也省去了设置图片背景偏移量带来的浏览器兼容性问题。

 一、在网页中显示base64编码的图片

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();
}

 二、将图片转化为base64字符串

  下面来说一下如何在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>

View Code

显示结果如图:

 小结

  我们可以看到,上面那么小的一张图片,转换成base64字符串后,会变成很长的一串字符串,如果我们将所有的图片都转换的话,虽然是网页打开速度会略有提升,但是代码会变的臃肿,难以维护。所以,我们可以将一些很小的图片转换成base64编码,嵌入到css文件中,如小的图标。

作者:雲霏霏

QQ交流群:243633526

博客地址:http://www.cnblogs.com/yunfeifei/

声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。非商业,未授权,贴子请以现状保留,转载时必须保留此段声明,且在文章页面明显位置给出原文连接。

如果大家感觉我的博文对大家有帮助,请推荐支持一把,给我写作的动力。

转载于:https://www.cnblogs.com/yunfeifei/p/4165351.html

浅析用Base64编码的图片优化网页加载速度相关推荐

  1. 汇总:web前端优化网页加载速度

    前言: 网页的加载流程:打开一个网页,会先拉取一个html页面,然后浏览器解析了这个html页面后,会根据页面的内容,去拉取javascript.css和图片文件,最终根据这些文件,将页面渲染出来.影 ...

  2. 分享网页加载速度优化的一些技巧?

    日期:2013-2-17  来源:GBin1.com 不管你是不是相信,在最近的几年里,互联网网页的大小已经显著增大了.由HTTP Archive研究得出的结果表明,目前平均一个页面的大小是1.25M ...

  3. 【PHP】如何提高网页加载速度?

    [php]如何提高网页加载速度? 1.减少页面请求: 从WEB运行原理上讲,IIS请求是无状态的,在服务器端一直是连接和关闭的不断进行着,如果能减少服务器请求,总的时间将会减少. 之前我下载163邮箱 ...

  4. 提高网页加载速度的一些方法和技巧

    网页的加载速度是评估网站质量一个重要指标,原因在于大多数用户能够容忍的网页加载时间只有几秒,如果超出了访客的忍受范围他们会毫不留情地关掉你的网页,所以网页载入速度会极大地影响网站的流量和访问. 以下总 ...

  5. 加快网页加载速度的五个有效的方法

    加快网页加载速度的五个有效的方法 Filed under: 未分类 | Posted on  五月 1st, 2010 by 林涛 网页尽可能的快速加载对网站非常重要:用户希望快速的查看他们想要看的页 ...

  6. Dns-prefetch DNS 预解析优化页面加载速度

    Dns-prefetch DNS 预解析优化页面加载速度 浏览器访问一个链接时并不是直接将请求到网页对应的服务器上,而是先要做域名解析--将域名解析到网页对应的服务器 ip 地址,然后浏览器才能和服务 ...

  7. uc点网页显示服务器升级,让uc浏览器网页加载速度提升100%

    摘要: 3G的最大特征就是网速的极大提升,而这正是 uc浏览器 手机浏览器的立身之本. 版本升级速度再提升100% 新发布的uc浏览器进一步改进了WAP/WEB网页的加载方式,不仅有效提高了浏览器的跳 ...

  8. Tomcat网页加载速度过慢的解决方法

    Tomcat网页加载速度过慢的解决方法 参考文章: (1)Tomcat网页加载速度过慢的解决方法 (2)https://www.cnblogs.com/magmell/p/7086229.html 备 ...

  9. 用 Flask 来写个轻博客 (28) — 使用 Flask-Assets 压缩 CSS/JS 提升网页加载速度

    Blog 项目源码:https://github.com/JmilkFan/JmilkFan-s-Blog 目录 目录 前文列表 扩展阅读 Flask-Assets 将 Flask-Assets 应用 ...

最新文章

  1. 软件测试用例优秀例子_功能测试用例设计方法分享
  2. java http请求
  3. C语言基于GTK+Libvlc实现的简易视频播放器(二)
  4. CentOS 安装及使用 terraform 最新教程
  5. sklearn线性回归详解
  6. 一、bootstrap4基础(布局系统、栅格系统、显示与隐藏、对齐与排列、内容排版、代码与图文、表格样式、颜色和边框、工具类)
  7. 防火墙技术之--状态防火墙ASPF(2)
  8. 存储空间的动态分配与释放
  9. 序列化与反序列化(XML、二进制)
  10. U盘写保护,量产工具修复。
  11. 犀牛脚本插件-添加文本-Python-显示窗口-rhino脚本
  12. google code 代码托管 用git创建仓库
  13. 2015CGMC 参赛游戏名单
  14. 典型相关分析python实现_多视图学习利器----CCA(典型相关分析)及MATLAB实现
  15. jQuery制作手风琴图片切换效果
  16. 谷歌首席决策科学家:AI难免犯错,唯有人类可以悬崖勒马
  17. Qt编写自定义控件:带阴影、圆角、可拉伸的弹窗
  18. java设计模式中—原型模式
  19. Linux中使用gzip来压缩/解压 *.gz文件
  20. 加载 linux 内核模块卡在 finit_module 系统调用处的问题

热门文章

  1. 线段树(数据结构,递归)
  2. JS验证邮箱格式是否正确的代码
  3. Unity与iOS原生代码之间的相互调用
  4. C++实现BMP转RAW
  5. 计算机网络 ,ip地址(网络号,主机号),网关,路由
  6. MATLAB-GUIDE简单示例
  7. 六年级下学期计算机课教学进度,六年级下册数学教学计划及进度表
  8. 蜚声国际的烹饪名厨们会选在哪开设食府?
  9. Android Q 按键启动recovery模式
  10. 华为路由器远程ssh登录配置