SVG 与 HTML5 的 canvas 各有什么优点,哪个更有前途

 我来答
梁氏子98
2016-07-24 · TA获得超过2096个赞
知道小有建树答主
回答量:914
采纳率:50%
帮助的人:528万
展开全部
  SVG
  SVG 是一种使用 XML 描述 2D 图形的语言。
  SVG 基于 XML,这意味着 SVG DOM 中的每个元素都是可用的。您可以为某个元素附加 JavaScript 事件处理器。
  在 SVG 中,每个被绘制的图形均被视为对象。如果 SVG 对象的属性发生变化,那么浏览器能够自动重现图形。

  Canvas
  Canvas 通过 JavaScript 来绘制 2D 图形。
  Canvas 是逐像素进行渲染的。
  在 canvas 中,一旦图形被绘制完成,它就不会继续得到浏览器的关注。如果其位置发生变化,那么整个场景也需要重新绘制,包括任何或许已被图形覆盖的对象。
  Canvas 与 SVG 的比较

  下表列出了 canvas 与 SVG 之间的一些不同之处。

  Canvas
  依赖分辨率
  不支持事件处理器
  弱的文本渲染能力
  能够以 .png 或 .jpg 格式保存结果图像
  最适合图像密集型的游戏,其中的许多对象会被频繁重绘

  SVG
  不依赖分辨率
  支持事件处理器
  最适合带有大型渲染区域的应用程序(比如谷歌地图)
  复杂度高会减慢渲染速度(任何过度使用 DOM 的应用都不快)
  不适合游戏应用
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式