没有合适的资源?快使用搜索试试~ 我知道了~
首页HTML5中SVG应用详解与代码实例
HTML5如何使用SVG的方法示例是一篇关于在HTML5中有效应用 Scalable Vector Graphics (SVG) 的教程。SVG 是一种基于XML的矢量图形格式,其优势在于其可缩放性、大小调整时的高质量保持、文件体积小、易于编辑以及与HTML、CSS和JavaScript的无缝集成。在HTML5中,SVG能够提供清晰的图标和图形,尤其在需要适应不同屏幕分辨率和设备性能的场景中,它具有显著的优势。 本文首先介绍了SVG的基本概念,强调了SVG作为文本文件而非像素图像的重要性,这意味着它不会因为缩放而失去清晰度,这对于网站性能优化非常有利。SVG支持的可搜索文本功能使其在制作地图和其他需要文本可交互的应用中表现出色,同时,SVG与Java技术的兼容性也为其在复杂动态场景中的应用提供了可能。 文章接下来通过实例演示了如何在HTML5中实际使用SVG,比如展示了如何通过`<svg>`标签嵌入SVG代码,以及一些关键属性如`viewBox`、`stroke`、`fill`和`path`元素的使用。例如,第三个分享图标的代码展示了如何定义路径和形状,通过`d`属性指定路径数据,以及`g`和`path`元素的组合来创建复杂的图形。 对于初次接触SVG的读者,文章提供了从基础到实践的指导,帮助读者理解SVG的工作原理,并通过实例学习如何将其融入到HTML5项目中进行代码优化。这篇文章对于希望提升网站性能、创建高质量矢量图形的前端开发者来说,是一份实用的参考资料。
资源详情
资源推荐
HTML5如何使用如何使用SVG的方法示例的方法示例
主要介绍了HTML5如何使用SVG的方法示例,详细的介绍了什么是SVG以及如何使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
代码优化永远是程序员亘古不变的需求,而合理的利用SVG图片来代替部分PNG/JPG等格式的图片则是前端优化重要的一环,既然是优化,那我们先来看看SVG图片都有哪些优势:
SVG 可被非常多的工具读取和修改(比如记事本)
SVG 与 JPEG 和 GIF 图像比起来,尺寸更小,且可压缩性更强。
SVG 是可伸缩的
SVG 图像可在任何的分辨率下被高质量地打印
SVG 可在图像质量不下降的情况下被放大
SVG 图像中的文本是可选的,同时也是可搜索的(很适合制作地图)
SVG 可以与 Java 技术一起运行
SVG 是开放的标准
SVG 文件是纯粹的 XML
几个SVG图片小例子:
我们来看一下第三个分享图标的代码:
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20">
<g stroke="#AAB0BA" fill="none" fill-rule="evenodd">
<path d="M10.524 3.413v8.235" stroke-linejoin="round"/>
<path d="M13.027 7.508c.813 0 1.678-.01 1.678-.01.449 0 .812.376.812.826l-.005 6.36a.819.819 0 0 1-.811.826H6.31a.822.822 0 0 1-.811-.826l.005-6.36c0-.456.36-.825.812-.825l1.689.006M8.373 5.111l2.143-2.09 2.143 2.07"/>
</g>
</svg>
不了解SVG的同学现在一定一脸问号,就跟我第一次见他们一样,别着急,我们从基础看起。
什么是什么是SVG??
SVG 是一种基于 XML 语法的图像格式,全称是可缩放矢量图(Scalable Vector Graphics)。其他图像格式都是基于像素处理的,SVG 则是属于对图像的形状描述,所以它本质上是文本文件,体积较
小,且不管放大多少倍都不会失真。此外SVG 是万维网联盟的标准,SVG 与诸如 DOM 和 XSL 之类的 W3C 标准是一个整体。
怎么使用?怎么使用?
在 HTML5 中,您能够将 SVG 元素直接嵌入 HTML 页面中,例如上面的那颗小红心:
<body>
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="20" height="20" viewBox="0 0 20 20">
<defs>
<rect id="a" y="54" width="60" height="25" rx="1"/>
<mask id="b" x="0" y="0" width="60" height="25" fill="#fff">
<use xlink:href="#a"/>
</mask>
</defs>
<g transform="translate(-9 -56)" fill="none" fill-rule="evenodd">
<use stroke="#EDEEEF" mask="url(#b)" stroke-width="2" xlink:href="#a"/>
<path d="M19.05 62.797c-.208-.268-1.776-2.188-3.629-1.725-.662.165-1.439.44-2.009 1.463-2.18 3.913 4.965 8.983 5.615 9.433V72l.023-.016.023.016v-.032c.65-.45 7.795-5.52 5.615-9.433-.57-1.023-1.347-1.298-2.009-1.463-1.853-.463-3.42 1.457-3.629 1.725z" fill="red"/>
</g>
</svg>
</body>
SVG 代码也可以写在一个以.svg结尾的文件中,然后用<img>、<object>、<embed>、<iframe>等标签插入网页。
<img src="search.svg">
<object id="object" data="search.svg" type="image/svg+xml"></object>
<embed id="embed" src="search.svg" type="image/svg+xml">
<iframe id="iframe" src="search.svg"></iframe>
CSS也可以使用svg
.logo {
background: url(logo.svg);
}
SVG 文件还可以转为 BASE64 编码,然后作为 Data URI 写入网页。
<img src="data:image/svg+xml;base64,[data]">
SVG的语法的语法
1. <svg>标签
SVG 代码都放在顶层标签<svg>之中。下面是一个例子。
<svg width="100%" height="100%">
<circle id="mycircle" cx="50" cy="50" r="50" />
</svg>
<svg>的width属性和height属性,指定了 SVG 图像在 HTML 元素中所占据的宽度和高度。除了相对单位,也可以采用绝对单位(单位:像素)。如果不指定这两个属性,SVG 图像默认大小是300像素
(宽) x 150像素(高)。
如果只想展示 SVG 图像的一部分,就要指定viewBox属性。
<svg width="100" height="100" viewBox="50 50 50 50">
<circle id="mycircle" cx="50" cy="50" r="50" />
</svg>
<viewBox>属性的值有四个数字,分别是左上角的横坐标和纵坐标、视口的宽度和高度。上面代码中,SVG 图像是100像素宽 x 100像素高,viewBox属性指定视口从(50, 50)这个点开始。所以,实际看到
的是右下角的四分之一圆。
注意,视口必须适配所在的空间。上面代码中,视口的大小是 50 x 50,由于 SVG 图像的大小是 100 x 100,所以视口会放大去适配 SVG 图像的大小,即放大了四倍。
如果不指定width属性和height属性,只指定viewBox属性,则相当于只给定 SVG 图像的长宽比。这时,SVG 图像的默认大小将等于所在的 HTML 元素的大小。
2. <circle>标签
<circle>标签代表圆形。
<svg width="300" height="180">
<circle cx="30" cy="50" r="25" />
<circle cx="90" cy="50" r="25" class="red" />
<circle cx="150" cy="50" r="25" class="fancy" />
</svg>
上面的代码定义了三个圆。<circle>标签的cx、cy、r属性分别为横坐标、纵坐标和半径,单位为像素。坐标都是相对于<svg>画布的左上角原点。
class属性用来指定对应的 CSS 类。
.red {
fill: red;
下载后可阅读完整内容,剩余3页未读,立即下载
weixin_38608873
- 粉丝: 6
- 资源: 980
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- OptiX传输试题与SDH基础知识
- C++Builder函数详解与应用
- Linux shell (bash) 文件与字符串比较运算符详解
- Adam Gawne-Cain解读英文版WKT格式与常见投影标准
- dos命令详解:基础操作与网络测试必备
- Windows 蓝屏代码解析与处理指南
- PSoC CY8C24533在电动自行车控制器设计中的应用
- PHP整合FCKeditor网页编辑器教程
- Java Swing计算器源码示例:初学者入门教程
- Eclipse平台上的可视化开发:使用VEP与SWT
- 软件工程CASE工具实践指南
- AIX LVM详解:网络存储架构与管理
- 递归算法解析:文件系统、XML与树图
- 使用Struts2与MySQL构建Web登录验证教程
- PHP5 CLI模式:用PHP编写Shell脚本教程
- MyBatis与Spring完美整合:1.0.0-RC3详解
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功