目录

【先言】

【题外话】

【问题】

1.定义

关于SVG(详见什么是SVG)

关于Canvas

2.两者区别

Canvas

SVG

对比列表

3.历史

4.功能

5.技术


【先言】

【题外话】

本来呢,就打算做完这套题呢该吃饭了,前面不定项选择都对了嘿,开心的,谁知道?后面?一看来了个“正确答案: A C   你的答案: B D (错误)”,哦豁!?!不得不吐槽下自己,伤感了,giao,不能吃饭的,都记的啥,都记反了?完美避开正确答案了,good服了,难道是?真的饿坏脑袋了吗?赶紧的,拿小本本记下先,罗里吧嗦的,www...

【问题】

以下说法中正确的是()

A、canvas 中绘制的元素不可以通过浏览器提供的接口获取到。

B、SVG 中绘制的元素不可以通过浏览器提供的接口获取到。

C、html 中 A标签 target 属性的默认取值是 _self,默认在当前窗口打开。

D、为了优化网页的SEO效果,常用 javascript 动态生成网页的title、description、keyword。

正确答案: A C   你的答案: B D (错误)


【知识点:Canvas与SVG】

1.定义

  • 关于SVG(详见什么是SVG)

    • SVG 可缩放矢量图形(Scalable Vector Graphics),基于可扩展标记语言XML 出来的时间比较老

SVG 用来定义用于网格的基于矢量的图形

  • 关于Canvas

    • Canvas 是H5新出来的标签
    • Canvas画布,利用JavaScript在网页绘制图像
    • 在标签中给上宽高: 不用加单位
    • 如果在css中给宽高 会对图像造成拉伸 (默认宽高300px*150px)
    • 通过过去绘制工具 .getContext(“2d”) 来在画布中绘制图形

2.两者区别

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

  • Canvas

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

  1. 不依赖分辨率
  2. 支持事件处理器
  3. 最适合带有大型渲染区域的应用程序(比如谷歌地图)
  4. 复杂度高会减慢渲染速度(任何过度使用 DOM 的应用都不快)
  5. 不适合游戏应用
  • 对比列表


3.历史

  • canvas是html5提供的新元素。
  • svg存在的历史要比canvas久远,已经有十几年了。svg并不是html5专有的标签,最初svg是用xml技术(超文本扩展语言,可以自定义标签或属性)描述二维图形的语言。

4.功能

  • canvas可以看做是一个画布,其绘制出来的图形为标量图。可以在canvas中引入jpg或png这类格式的图片。在实际开发中,大型的网络游戏都是用canvas画布做出来的,并且canvas的技术现在已经相当的成熟。另外,我们喜欢用canvas来做一些统计用的图表,如柱状图曲线图或饼状图等。
  • svg,所绘制的图形为矢量图,不能引入普通的图片,因为矢量图的不会失真的特点,在项目中我们会用来做一些动态的小图标。这个特点也很适合被用来做地图,百度地图就是用svg技术做出来的。

5.技术

  • canvas里面绘制的图形不能被引擎抓取,canvas中我们绘制图形通常是通过javascript来实现。
  • svg里面的图形可以被引擎抓取,支持事件的绑定,svg更多的是通过标签来实现。我再来介绍一个svg的js库:TWO.JS。其中包含two.js和three.js前者用于绘制二维图形,后者用于绘制三维图形。TWO.JS可以支持三种格式,svg(默认)、canvas、和WEBGL。当然也可以在普通div中引入。

o了o了,学废了,两点了该系饭辽,下次再没记住得喝白开水了!!

前端4-2-10:Canvas与SVG之简介、对比总结相关推荐

  1. 【前端】CSS3、Canvas、SVG等5种方式实现水波纹波浪动画特效

    目录 一.CSS3动画+图片波浪效果 1. 效果图 2. 代码 3. 原理 二.纯CSS3圆盘波浪进度效果 三.纯CSS3涟漪效果 四.Canvas波浪效果 五.SVG+jQuery波浪效果 六.源码 ...

  2. 《Web前端开发精品课——HTML5 Canvas开发详解》——第一部分第二章节

    本节书摘来自异步社区<Web前端开发精品课--HTML5 Canvas开发详解>一书中的第1部分,第2章,作者:莫振杰 著,更多章节内容可以访问云栖社区"异步社区"公众 ...

  3. HTML5 Canvas、内联 SVG、Canvas vs. SVG

    canvas 元素用于在网页上绘制图形. 什么是 Canvas? HTML5 的 canvas 元素使用 JavaScript 在网页上绘制图像. 画布是一个矩形区域,您可以控制其每一像素. canv ...

  4. H5中canvas和svg绘图方式介绍

    在HTML5中包括了两种绘图方式,canvas和svg(矢量呈现),而与canvas不同的是,svg是一种XML标记语言,它既可以单独保存以".svg"为后缀的文件在浏览器中打开显 ...

  5. Canvas or SVG?一张好图,两手准备,就在 ECharts 4.0

    Canvas 和 SVG 是两大基于浏览器的渲染方案,在选择图表库的时候,用户有时也会在这两者之间纠结.但是纠结的时候,你是否真的明白这两者在哪些方面有优劣? ECharts 4.0 推出 Canva ...

  6. canvas webGL SVG 比较

    https://blog.csdn.net/Thea12138/article/details/79723380 对每个类型的封装库:https://blog.csdn.net/u010513603/ ...

  7. html5 svg特性,HTML5新特性——HTML 5 Canvas vs. SVG

    Canvas 和 SVG 都允许您在浏览器中创建图形,但是它们在根本上是不同的. SVG SVG 是一种使用 XML 描述 2D 图形的语言. SVG 基于 XML,这意味着 SVG DOM 中的每个 ...

  8. 前端实战小案例--canvas实战之FlappyBird小游戏

    前端实战小案例--canvas实战之FlappyBird小游戏 想练习更多前端案例,请进个人主页,点击前端实战案例->传送门 觉得不错的记得点个赞?支持一下我0.0!谢谢了! 不积跬步无以至千里 ...

  9. HTML画布与SVG(Canvas vs. SVG)

    目录 画布(Canvas) 什么是 Canvas? 创建 Canvas 元素 通过 JavaScript 来绘制 理解坐标 更多 Canvas 实例 实例 - 线条 实例 - 圆形 实例 - 渐变 实 ...

最新文章

  1. android WebSocket 发送图片
  2. Metrics.NET 项目
  3. Python class 类中 __init__ 函数
  4. php array_only,php可以定义数组的常量吗
  5. 【WEB API项目实战干货系列】- API访问客户端(WebApiClient适用于MVC/WebForms/WinForm)(四)
  6. 统计代码行数的方法梳理
  7. 查看局域网内所有ip 和 mac
  8. 全国大数据分析系统基于vue echarts
  9. PMP考试有哪些技巧?(技巧+资料分享)
  10. 安装VS2010 SP1失败,安装VS2010 SP1时出现回滚,
  11. abb机器人写字程序实例_ABB机器人编程之程序流程指令(含案例)
  12. 数据不落地、移动新应用、安全更可靠
  13. fatal: ‘http://git.#####.com/test-auto/stability.git/‘ 鉴权失败
  14. Q3净利润同比涨超313%,金山办公为何不能松懈?
  15. 我学炒外汇 第二十二篇实战心得
  16. LiveQing流媒体RTMP推流服务-如何获直播流地址 HLS/HTTP-FLV/WS-FLV/WebRTC/RTMP视频流地址
  17. 打开WPS或office,提示运行时错误‘424’或 运行错误‘429’,ActiveX部件不能创建对象
  18. SAP 上传图片至系统
  19. 想哭!我相信“官方”消息,炒币仍然被骗
  20. 单选按钮、复选框、下拉框的回显

热门文章

  1. python爬取天气数据_用python爬取历史天气数据的方法示例
  2. 懒癌患者的学习记录之JAVA简单插入排序
  3. 凸包 (Convex Hull)
  4. sql日报周报月报季报年报
  5. Unity TextMeshPro图文混排
  6. coco class name
  7. Microsoft COCO (Common Objects in Context) dataset - COCO Explorer
  8. 同济大学符长虹教授讲无人机+视觉
  9. 读《那些忧伤的年轻人》有感
  10. 论文编辑中wps问题和技巧