在使用生成的svg图作为<img>标签是src值时,发现有部分浏览器显示异常,所以这里记录下

参考链接

Data URLs

http://www.faqs.org/rfcs/rfc2397.html

https://developer.mozilla.org/zh-CN/docs/Web/HTTP/data_URIs

URL hash

http://www.ruanyifeng.com/blog/2011/03/url_hash.html

https://developer.mozilla.org/zh-CN/docs/Web/API/URL/hash

<img src="Data URLs">中,Data URLs格式与显示情况如下:

//1. 部分浏览器不能正常显示
data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="50" height="50"><rect fill="#795548" x="0" y="0" width="100%" height="100%"></rect><text fill="#FFF" x="50%" y="50%" text-anchor="middle" alignment-baseline="central" font-size="16" font-family="Verdana, Geneva, sans-serif">jack</text></svg> //2. 采用base64编码svg,正常显示
data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI1MCIgaGVpZ2h0PSI1MCI+PHJlY3QgZmlsbD0iIzc5NTU0OCIgeD0iMCIgeT0iMCIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSI+PC9yZWN0Pjx0ZXh0IGZpbGw9IiNGRkYiIHg9IjUwJSIgeT0iNTAlIiB0ZXh0LWFuY2hvcj0ibWlkZGxlIiBhbGlnbm1lbnQtYmFzZWxpbmU9ImNlbnRyYWwiIGZvbnQtc2l6ZT0iMTYiIGZvbnQtZmFtaWx5PSJWZXJkYW5hLCBHZW5ldmEsIHNhbnMtc2VyaWYiPmphY2s8L3RleHQ+PC9zdmc+ //3. 采用%23转义#,正常显示
data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="50" height="50"><rect fill="%23795548" x="0" y="0" width="100%" height="100%"></rect><text fill="%23FFF" x="50%" y="50%" text-anchor="middle" alignment-baseline="central" font-size="16" font-family="Verdana, Geneva, sans-serif">jack</text></svg> //4. 采用rgb代替hex color,正常显示
data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="50" height="50"><rect fill="rgb(121,85,72)" x="0" y="0" width="100%" height="100%"></rect><text fill="rgb(255,255,255)" x="50%" y="50%" text-anchor="middle" alignment-baseline="central" font-size="16" font-family="Verdana, Geneva, sans-serif">jack</text></svg>

上面给出的Data URLs中第一个与其他的不同之处就是包含了URL的敏感字符#,其被作为hash使用,用于浏览器网页内部的网页位置指定标识符,#后面出现的任何字符,都会被浏览器解读为位置标识符。

这里我用以上链接直接使用浏览器访问,73版谷歌浏览器和66版火狐浏览器对于第一个Data URLs给出的结果都是解析异常,这里我的猜测(意淫)就是这种Data URLs其实是浏览器内部识别了URL标识,其又充当了一台服务器,对当前Data URLs进行解析,之后内部直接给出数据。而它们在处理data:image/svg+xml时将#后面的字符串当做为位置标识符,没有将#后数据提交至浏览器内部解析器(我认为的模拟服务器)中,所以就出现了数据丢失解析异常。

以上分析纯属个人猜测。反正这里需要注意的就是,采用Data URLs时有可能出现URL特殊字符,最好能够对其进行编码,或者转义。

最新文章

  1. Qt 之 数字钟
  2. Android客户端消息推送原理简介
  3. Makefile 编译生成多个可执行文件
  4. 5月21日 CSS样式表加阴影
  5. c标签的使用方法
  6. unity之uv贴图画圆弧,圆弧面,不规则图形
  7. Hibernate的一些相关信息
  8. iOS 错误 之 Potential leak of an object stored into &#39;cs&#39;
  9. Mybatis--01
  10. httpclient实现的get请求及post请求
  11. 〖Android〗我的ADT Eclipse定制
  12. python day04作业
  13. centos7 真实机安装后没有网卡解决办法
  14. php 保存文件
  15. 路由器子网掩码设置不正确导致github无法访问
  16. 20155306 白皎 《网络攻防》 Exp2 后门原理与实践
  17. SGU 406 Goggle
  18. 找到当前mysql group replication 环境的primary结点
  19. sass的学习笔记
  20. SQLite metadata

热门文章

  1. python_重写数组
  2. 基于.net的分布式系统限流组件
  3. OVMF基础
  4. JXP
  5. RecyclerView android
  6. Linux内核参数调优
  7. 阿里云部署java项目参考如下链接
  8. pycharm跨目录调用文件
  9. 前端学习总结(一)——常见数据结构的javascript实现
  10. Spring Data Jpa 实现分页(Spring MVC+easyui)