Canvas 和 SVG 的區(qū)別

什么是SVG?

SVG 指可伸縮矢量圖形 (Scalable Vector Graphics)
  SVG 用來定義用于網(wǎng)絡(luò)的基于矢量的圖形
  SVG 使用 XML 格式定義圖形
  SVG 圖像在放大或改變尺寸的情況下其圖形質(zhì)量不會有所損失
  SVG 是萬維網(wǎng)聯(lián)盟的標準
  SVG 與諸如 DOM 和 XSL 之類的 W3C 標準是一個整體

Canvas 和 SVG 的區(qū)別:

SVG

SVG 是一種使用 XML 描述 2D 圖形的語言。
    SVG 基于 XML,這意味著 SVG DOM 中的每個元素都是可用的。您可以為某個元素附加 JavaScript 事件處理器。
    在 SVG 中,每個被繪制的圖形均被視為對象。如果 SVG 對象的屬性發(fā)生變化,那么瀏覽器能夠自動重現(xiàn)圖形。
    特點:
       不依賴分辨率
       支持事件處理器
       最適合帶有大型渲染區(qū)域的應(yīng)用程序(比如谷歌地圖)
       復(fù)雜度高會減慢渲染速度(任何過度使用 DOM 的應(yīng)用都不快)
       不適合游戲應(yīng)用

Canvas

Canvas 通過 JavaScript 來繪制 2D 圖形。
    Canvas 是逐像素進行渲染的。
    在 canvas 中,一旦圖形被繪制完成,它就不會繼續(xù)得到瀏覽器的關(guān)注。如果其位置發(fā)生變化,那么整個場景也需要重新繪制,包括任何或許已被圖形覆蓋的對象。
    特點:
      依賴分辨率
       不支持事件處理器
       弱的文本渲染能力
       能夠以 .png 或 .jpg 格式保存結(jié)果圖像
       最適合圖像密集型的游戲,其中的許多對象會被頻繁重繪

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容