您现在的位置是:网站首页> 编程资料编程资料
Data URI scheme详解和使用实例及图片base64编码实现方法使用data URI scheme在网页中内嵌图片使用介绍
2023-10-14
563人已围观
简介 这篇文章主要介绍了Data URI scheme详解和使用实例及图片base64编码实现方法,需要的朋友可以参考下
一、 Data URI scheme 简介
Data URI scheme是在RFC2397中定义的,目的是将一些小的数据,直接嵌入到网页中,从而不用再从外部文件载入。比如上面那串字符,其实是一张小图片,将这些字符复制黏贴到火狐的地址栏中并转到,就能看到它了,一张1X36的白灰png图片。
在上面的Data URI中,data表示取得数据的协定名称,image/png 是数据类型名称,base64 是数据的编码方法,逗号后面就是这个image/png文件base64编码后的数据。
或许你已经注意到,在有的网页上,图片的 src 或 css 背景图片的 url 并不是我们常见的在线图片链接,而是一大串的字符,比如像这样:
这是什么呢?这就是今天要介绍的 Data URI scheme。
目前,Data URI scheme支持的类型有:
data:,文本数据
data:text/plain,文本数据
data:text/html,HTML代码
data:text/html;base64,base64编码的HTML代码
data:text/css,CSS代码
data:text/css;base64,base64编码的CSS代码
data:text/javascript,Javascript代码
data:text/javascript;base64,base64编码的Javascript代码
data:image/gif;base64,base64编码的gif图片数据
data:image/png;base64,base64编码的png图片数据
data:image/jpeg;base64,base64编码的jpeg图片数据
data:image/x-icon;base64,base64编码的icon图片数据
base64简单地说,它把一些 8-bit 数据翻译成标准 ASCII 字符,在PHP中可以用函数base64_encode() 进行编码。
目前,IE8、Firfox、Chrome、Opera浏览器都支持这种小文件嵌入。对于 IE7 及之前版本,可通过使用MHTML 解决 data URI scheme 的兼容问题。
举例说明
网页中一张图片可以这样显示:

也可以这样显示:
我们把图像文件的内容直接写在了HTML 文件中,这样做的好处是,节省了一个HTTP 请求使得加载速度得以提升,坏处则可能导致浏览器不会缓存这种图像。
二、图片 base64 编码的实现方法示例
2.1 JS实现图片 base64 编码代码
function readFile(){
var file = this.files[0];
if(!/image\/\w+/.test(file.type)){
alert("请确保文件为图像类型");
return false;
}
var reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = function(e){
result.innerHTML = '
img_area.innerHTML = '
}
}
2.2 利用 HTML5 的 FileReader 实现图片 base64 编码
HTML5 Javascript 版本核心代码:
function readFile(){
var file = this.files[0];
if(!/image\/\w+/.test(file.type)){
alert("请确保文件为图像类型");
return false;
}
var reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = function(e){
result.innerHTML = '
img_area.innerHTML = '
}
}
相关内容
- html5实现canvas阴影效果示例canvas 阴影和图形变换的示例代码HTML5 canvas基本绘图之绘制阴影效果实例讲解使用HTML5 Canvas绘制阴影效果的方法HTML5 Canvas阴影使用方法实例演示canvas多重阴影发光效果实现
- Html5 语法与规则简要概述HTML学习笔记--HTML的语法详解(必看)简单整理HTML5的基本特性和语法详解HTML&CSS&JavaScript语法辞典-(专业版) (半场方人) PDF扫描版 93.1HTML5的语法变化介绍HTML5 新旧语法标记对我们有什么好处HTML语法大全_html语言语法大全(必看)
- html5桌面通知(Web Notifications)实例解析Html5中的桌面通知Notification的实现HTML5实现桌面通知 提示功能HTML5实现Notification API桌面通知功能 突袭HTML5之Javascript API扩展5—其他扩展(应用缓存/服务端消息/桌面HTML5中的Web Notification桌面通知功能的实现方法
- 天天飞车刷金币刷分攻略心得 天天飞车辅助教程大全_手机游戏_游戏攻略_
- 全民英雄圣诞版英雄碎片如何获得 圣诞版英雄碎片获得方法_手机游戏_游戏攻略_
- 天天飞车12月16日刷分刷钱快速至1亿攻略心得_手机游戏_游戏攻略_
- 天天飞车高分技巧攻略 天天飞车如何获得高分_手机游戏_游戏攻略_
- 天天飞车哪个车手最厉害 天天飞车都有哪些车手_手机游戏_游戏攻略_
- 天天飞车赛车选择技巧经验 天天飞车赛车有哪些_手机游戏_游戏攻略_
- 天天飞车葫芦侠修改器刷分刷金币辅助教程攻略分享_手机游戏_游戏攻略_
