【前端】DataURL 用法

文章目录

一、基本介绍

  • Data-URL:是以data:为前缀,特殊格式的URL,可以将小文件嵌入在文档中。
js 复制代码
/*
	mediatype:表明数据类型,如image/jpeg表示一个jpeg图片文件,默认值为:text/plain;charset=US-ASCII
	encoding:数据编码方式(默认US-ASCII,BASE64两种)
	data:编码后的数据
*/
data:[mediatype][encoding],data
  • mediatype
类型 描述 示例
text 普通文件 text/plain,text/html,text/css,text/javascript
image 图像文件 image/gif,image/png,image/jpeg,image/bmp,image/webp,image/x-icon,image/vnd.microsoft.icon
audio 音频文件 audio/midi,audio/mpeg,audio/webm,audio/ogg,audio/wav
video 视频文件 video/webm,video/ogg
application 二进制数据 application/octet-stream,application/pkcs12,application/vnd.mspowerpoint,application/xhtml+xml,application/xml,application/pdf
  • 示例:先将文件转成base64编码,再通过Data URL,我们把图像内容内置在HTML 中。
html 复制代码
<!-- 常规url -->
<img src="http://csdn.com/img/test.jpg">
<!-- dataurl -->
<img src="data:image/png;base64,alsdkfj...">

二、优点缺点

优点:

  1. 减少 HTTP 请求,例如图片体积小,这是还占用一个请求就不值得

  2. 能够在离线情况下访问,而不依赖于外部资源的可用性

缺点:

  1. Base64 编码后的数据体积 会比 原数据的体积大
  2. Data URL 形式的图片不被浏览器缓存,每次访问页面时都会重新下载一次。
  3. 由于 Base64 跟 CSS 混在一起,增加了浏览器解析CSS树的耗时
  4. IE678 存在兼容性问题
  5. 不适合懒加载,可读性差,也不利于维护
相关推荐
执行部之龙6 小时前
JS手写——call bind apply
前端·javascript
京东零售技术6 小时前
告别手动搬砖: JoyCode + i18n-mcp 实现前端项目多语言自动化
前端
李少兄6 小时前
企业资源计划(ERP)系统全景指南
java·前端·数据库·erp
张一凡936 小时前
React 项目也能用依赖注入?我尝试了一下,真香
前端·react.js
somebody6 小时前
零经验学 react 的第15天 - 过渡动画(使用 react-transition-group 库进行实现)
前端
SuperEugene6 小时前
Vue3 + Element Plus 表单开发实战:防重复提交、校验、重置、loading 统一|表单与表格规范篇
前端·javascript·vue.js
SuperEugene6 小时前
Vue3 + Element Plus 中后台弹窗规范:开闭、传参、回调,告别弹窗地狱|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
桜吹雪6 小时前
在前端运行Qwen3.5原生多模态模型
前端·人工智能·机器学习
孟祥_成都6 小时前
前端下午茶:这 3 个网页特效建议收藏(送源码)
前端·javascript·css
SuperEugene6 小时前
VXE-Table 4.x 实战规范:列配置 + 合并单元格 + 虚拟滚动,避坑卡顿 / 错乱 / 合并失效|表单与表格规范篇
开发语言·前端·javascript·vue.js·前端框架·vxetable