SVG和HTML5 Canvas的区别是什么?
HTML 的<svg>元素是SVG图形的容器。SVG代表可缩放矢量图形。SVG用于定义图形,例如方框、圆形、文本等。SVG代表可缩放矢量图形,它是一种使用XML描述二维图形和图形应用程序的语言,然后由SVG查看器呈现。大多数网页浏览器可以像显示PNG、GIF和JPG一样显示SVG。
HTML 的<canvas>元素用于通过JavaScript绘制图形。<canvas>元素是图形的容器。
| SVG | HTML Canvas |
|---|---|
| SVG具有更好的可扩展性。因此,它可以以任何分辨率高质量打印。 | Canvas的可扩展性较差。因此,它不适合在更高分辨率下打印。 |
| SVG在对象数量较少或表面积较大的情况下性能更好。 | Canvas在表面积较小或对象数量较多的情况下性能更好。 |
| SVG可以通过脚本和CSS修改。 | Canvas只能通过脚本修改。 |
| SVG是基于矢量的,由形状组成。 | Canvas是基于光栅的,由像素组成。 |
示例
您可以尝试运行以下代码,将可缩放矢量图形(SVG)添加到网页:
<!DOCTYPE html>
<html>
<head>
<style>
#svgelem {
position: relative;
left: 50%;
-webkit-transform: translateX(-20%);
-ms-transform: translateX(-20%);
transform: translateX(-20%);
}
</style>
<title>HTML5 SVG</title>
</head>
<body>
<h2 align = "center">HTML5 SVG Circle</h2>
<svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
<circle id = "bluecircle" cx = "60" cy="60" r = "50" fill = "blue" />
</svg>
</body>
</html>示例
您可以尝试运行以下代码,学习如何使用HTML5 Canvas绘制矩形:
<!DOCTYPE html>
<html>
<head>
<title>HTML5 Canvas Tag</title>
</head>
<body>
<canvas id = "newCanvas" width = "200" height = "100" style = "border:1px solid #000000;"></canvas>
<script>
var c = document.getElementById('newCanvas');
var ctx = c.getContext('2d');
ctx.fillStyle = '#7cce2b';
ctx.fillRect(0,0,300,100);
</script>
</body>
</html>
广告
数据结构
网络
关系数据库管理系统 (RDBMS)
操作系统
Java
iOS
HTML
CSS
Android
Python
C语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP