在网页中添加矢量图形,

  使用矢量图形在很多情况下,效果较好,拥有较小的文件尺寸,高度缩放,下面具体讲解如何在网页中添加矢量图形

  位图和矢量图

  位图文件包含了每个像素的位置和色彩信息,流行的位图格式包括Bitmap(.bmp),PNG(.png),JPEG(.jpg)和GIF(.gif)

  矢量图使用算法来定义,一个矢量图包含了图形和路径的定义,电脑可以根据这些定义计算出他们在屏幕上时呈现的样自,SVG用于创造精彩的web矢量图形。矢量图相对于同样的位图有更小的体积,因为仅需存储少量的算法,而不是逐个存储每个像素的信息。

  SVG的定义

SVG用于描述矢量图形的XML语言,基本上时像HTML一样的标记,用于图形,有一些简单元素来出创建简单图形。<circle><rect><feColorMatrix>(变换矩阵转换颜色) <animate>矢量图形的动画部分,<mask>在图像顶部应用蒙版。下面展示i一个简单的例子:

<svg version="1.1" baseProfile="full" width="300" height="2000" xmlns="http://www.w3.org/2000.svg">

  <rect width="100%" height="100%" fill="back"  />

  <circle  cx="150" cy="100" r="90"  fill="blue" />

</svg> 可以使用illustrator来创建各种插图,

SVG其他优点,矢量图形中的文本仍然可访问利于SEO,可以很好的适应样式/脚本。缺点 ,SVG非常容易变得复杂,文件大小会增加也会占用浏览器很长的处理时间。

SVG可能比栅格图像更难创建,取决于创建那种图像,SVG从IE9开始支持,因此光栅图形跟适合照片那样复杂精密的图像。

  将SVG添加到页面,使用img快捷方式,用src属性引用SVG。示例如下:

<img
src="equilateral.svg"
alt="triangle with all three sides equal"
height="87px"
width="100px" />

优点,快速,熟悉的图像语法,alt属性提供的内置文本等效,可以通过a元素嵌套img使图像成为超链接。  缺点,无法使用js实现操作图像,如果要操作样式必须内联CSS样式,外部样式不起作用,也不能用CSS伪类来重设图像样式(:focus)

  兼容性,对于不支持SVG IE8及更低版本,Android2.3及更低版本的浏览器,可以从src属性引用png或jpg,并使用srcset属性,只有最近的浏览器才能识别来引用SVG,这样支持SVG的浏览器将使用SVG,较旧的浏览器将加载PNG, 同样也可以通过CSS来讲SVG设置成背景图像,

background:url("fallback.png") np-repeat cener;

background-image:url("image.svg");

background-size:contain;

同样这种方式引入的SVG无法被js操作,样式设置也有了限制,限于内联样式。

引用SVG时,确保内联SVG即在标签内,优点,SVG内联减少HTTP请求,减少加载时间。

使用id或class选定SVG元素,添加央视规则。内联SVG唯一可以让CSS与其交互,CSS动画的方法,同样也可以包裹在a元素里,成为超链接。

缺点:多次使用导致资源密集难以维护,  SVG增加HTML文件大小,  浏览器不能像缓存普通图片一样缓存内联SVG,  在<foreignObject>元素中 包含回退,支持SVG的浏览器让然会下载后备图像。

  使用iframe嵌入SVG 像在网页中打开网页一样,打开SVG图像,

<iframe src="triangle.svg" width="500" height="500" sandbox>
<img src="triangle.png" alt="Triangle with three unequal sides" />
</iframe>

来分析下这种情况的优缺点,iframe有回退机制,如果浏览器不支持iframe,则只会显示回退,此外,除非SVG和您的当前网页有相同的origin,否则不能在主页面上使用js操作SVG.

HTML入门11的更多相关文章

  1. Cesium入门11 - Interactivity - 交互性

    Cesium入门11 - Interactivity - 交互性 Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ ...

  2. Kotlin入门(11)江湖绝技之特殊函数

    上一篇文章介绍了Kotlin对函数的输入参数所做的增强之处,其实函数这块Kotlin还有好些重大改进,集中体现在几类特殊函数,比如泛型函数.内联函数.扩展函数.尾递归函数.高阶函数等等,因此本篇文章就 ...

  3. springcloud 入门 11 (Hystrix Dashboard)

    hystrix: 断路器我在前面已经介绍,不了解的可以参考 :springcloud 入门 6 (断路器hystrix)  关于搭建,测试我都在这里面进行说明了,这章介绍的是  Hystrix Das ...

  4. SVG 2D入门11 - 动画

    交互性      SVG拥有良好的用户交互性,例如:1. SVG能响应大部分的DOM2事件.2. SVG能通过cursor良好的捕捉用户鼠标的移动.3. 用户可以很方便的通过设置svg元素的zoomA ...

  5. [转]ASP.NET MVC 入门11、使用AJAX

    在ASP.NET MVC beta发布之前,M$就宣布支持开源的JS框架jQuery,然后ASP.NET MVC beta发布后,你建立一个ASP.NET MVC beta的项目后,你可以在项目的sc ...

  6. C# 经典入门11章,比较

    1类型比较 所有的类懂从System.Object中继承了GetType()方法,这个方法和typeof()运算符一起使用,可以确定对象的类型.例如: if(myObj.GetType()==type ...

  7. Linux入门(11)——Ubuntu16.04安装texlive2016并配置texmaker和sublime text3

    安装过程中需要调用 Perl 的模块 Digest::MD5 来检测 ISO 文件的完整性:升级过程中界面需要调用 Perl 的模块 Tk: sudo apt-get install libdiges ...

  8. JAVA入门[11]-jsp几点基础语法

    一.include <%@include file="copyright.jsp"%> <jsp:include page="copyright.jsp ...

  9. 从壹开始前后端分离【 .NET Core2.0 +Vue2.0 】框架之十一 || AOP自定义筛选,Redis入门 11.1

    代码已上传Github+Gitee,文末有地址 书说上文<从壹开始前后端分离[ .NET Core2.0 Api + Vue 2.0 + AOP + 分布式]框架之十 || AOP面向切面编程浅 ...

随机推荐

  1. SimpleDateFormat日期格式解析

    先看一个代码示例: import java.text.SimpleDateFormat; import java.util.Date; public class test{ public static ...

  2. BUGKU login3

    先看的wp,呢么来复现一遍,emmmmmm,尝试一波,用户名输入admin后,密码随便输,发现提示password error,呢么填其他用户名的话,发现提示username does not exi ...

  3. 在JavaScript中,如何判断数组是数组?

    如果你没有注意过这个问题,那么这个标题应该会让你感到困惑,判断数据类型这么基础的问题能有什么坑呢? 少年,你不能太天真了,我们朝夕面对的这门语言,可是JavaScript呀,任何你觉得已经习以为常的东 ...

  4. ffmpeg错误:Invalid UE golomb code

    解决方案在github https://github.com/FFmpeg/FFmpeg/commit/c51c08e0e70c186971385bdbb225f69edd4e3375 问题简要描述为 ...

  5. css奇技淫巧-色彩渐变与动态渐变

    来源 css渐变 CSS 中设置的渐变是 gradient 数据类型,它是一种特别的image数据类型.使用background-image设置,可叠加设置多个: CSS3 定义了两种类型的渐变(gr ...

  6. ASP.NET Core 中使用Session会话

    添加Session Nuget包 更新Startup.cs文件 在ConfigureServices方法中添加如下代码 services.AddSession(options => { // S ...

  7. luoguP2502旅行

    2006河南省选 思路:(参考题解) 枚举最大的边(第\(i\)条),从这条边开始由大到小枚举.添边,当\(s\)和\(t\)联通时,此时即为以第\(i\)条边为最大边的答案,比较每个答案,判断输出. ...

  8. centos7系统部署cobbler批量安装系统

    系统环境: 一.开启两个网卡.一个仅主机模式,一个桥接模式,主机模式对内提供cobbler服务 [root@localhost ~]# ip a 1: lo: <LOOPBACK,UP,LOWE ...

  9. CocosCreator脚本中向依赖的组件赋值后, 被依赖的组件没有取到值的问题!

    问题描述: 两个节点parent&child(其中都包含脚本组件), parent脚本组件依赖了child组件, 节点关系如下图: parent脚本内容如下: child脚本内容如下: 预览时 ...

  10. ORACLE安装报错解决

    今天在虚拟机中安装了一个WINDOWS系统,用于安装oracle服务器:从安装到使用中出现了很多的问题,把这些问题解决掉,花了不少时间,查了不少的资料. 第一个,我在安装过程中,出现了ORA-0092 ...