svg的学习

1,初步了解

1,大致看了一下svg的简介,在图形的操作和展示上有很大的优势,例如不会失精;灵活的dom操作;很好的兼容性(IE需要下载插件)。so,是一门值得深究的前端课程;

2,看了一个小demo,使用xml的语言,创建.svg后缀文件(文件的后缀名可认为是一种标识,文件解析不会按照文件去解析,so html or js or xml解析时,与放在什么样的文件里面是没有关系的)

2,小试牛刀

1,demo总结点;

  (1)standalone该文件是否独立,当对外部文件有引入时,standalone=‘no’;当值为‘yes’时,表示当前文件不需要依靠外部文件,自包含;不会报错。

  (2)需要将svg文件引入html中时,提供了几个标签,embed;iframe;object;img,并提供属性执行下载显示插件。经实验,支持性受限。支持性较好的是Object,Object之间的标签是用来在Object不显示的情况下渲染的。

  (3)命名空间的理解;xmlns,当前以及子空间,解析需要的语言命名。

  (4)当svg不设置高宽,没有viewbox属性时,svg默认值是300*150;如果有viewbox属性,svg的默认是html的大小。

  (5)viewbox(x,y,width,height)理解点:从x,y坐标,截取50宽,50长的画布区域,放在width 100 height 100 的svg画布上放大显示。

  (6)patternUnits两个值得区别,objextBoundingBox按照比例定宽高平铺;userSpaceOnUse按照引用对象宽度全铺。

  (7)svg的样式定义时,需要display:block  ---- svg画图时,样式定义遇到疑难点

  (8)当svg使用了viewbox属性,子元素的宽高失效,按照比例显示 ---- svg画图时,布局问题

  (9)svg添加文本,是否只能绘制文本了?innerHtml之类是否可用?-------text

  (10)svg被作为外部文件引入时,不会继承在父文档中的任何样式?

  (11)preserveAspectRatio的取值区别和使用?--- 当我们在使用viewBon将画布进行裁剪等操作后,的图形放在svg图形的什么位置 xMinYMax等

  (12)需分清楚svg中哪些元素可嵌套,哪些不可嵌套?circle中写text是没法正常显示的。

  (13)关于text,一篇不错的文章---https://www.cnblogs.com/fzz9/p/9256265.html

  (14)想要一个组只有在被引用的时候,显示,使用defs。

  (15)使用createElement动态创建svg元素,失效 ----- 踩坑  ----使用createElementNS,与createElemen相似,可以指定命名空间。

  (16)操作svg的元素时,遇到了shadow-root问题,导致不法操作其中dom。

mode为open时,我们可以使用shadowRoot(隐藏的dom树结构)进行访问,如下图所示

当mode是close的时候,隐藏的dom是不支持访问的;so...当我们需要动态使用use创建dom,并且需要支持修改use引用的g或者defs dom里面的内容,我们只能需要通过在js里面动态创建了;

html:

js:  

结果:

解决办法:将组的生成放在js当中动态生成

效果图:

svg的学习的更多相关文章

  1. SVG相关学习(一)SVG基础

    SVG 相关学习 SVG SVG 指可伸缩矢量图形 (Scalable Vector Graphics) SVG viewBox <svg width="500" heigh ...

  2. SVG绘图学习总结

    在我们平时做的很多网站项目中都会需要绘制各种各样的二维矢量图形.比如做城市地下管网的断面图.管线管点的坐标位置矢量标识图.钻孔位置或地层剖面图等等.我们有很多中方法来绘制这些矢量图(vml.canva ...

  3. JavaScript权威设计--jQuery,Ajax.animate,SVG(简要学习笔记二十)[完结篇]

    1.$和jquery在全局命名空间中定义的唯一两个变量.   2.jquery是工厂函数,不是构造函数.他返回一个新创建的对象.   3.jquery的四种调用方式:     <1>传递C ...

  4. svg动画学习

    首先我们定义一块画布,然后在上面画一个圆形. 他看起来应该是这个样子的:(每一个实例我都会附加图片以及demo链接,方便直观的理解与源代码的查看,查看的时候请使用标准浏览器) 点击查看Demo 现在我 ...

  5. svg滤镜学习

    SVG滤镜绝对称得上是他最强大的功能之一,在不影响任何文档结构的前提下,允许你给你的矢量图形添加各种专业视觉效果,我个人给他的定义就是,把PS装到了网页上. 一.  SVG滤镜的原理 基本原理描述太多 ...

  6. SVG的学习(34—36)

    使用js来动态绘制svg图片,首先就是要创建svg 节点. 使用createElementNS(),语法: document.createElementNS(namespaceURI, qualifi ...

  7. SVG图像学习

    参考阮一峰老师: SVG 图像入门教程 基本使用 可以直接放入到html中 <body> <svg viewBox="0 0 800 600" > < ...

  8. d3 svg简单学习

    矩形 <rect x="/> 圆形 <circle cx="/> 椭圆 <ellipse cx="/> 线 <line x1=& ...

  9. 【Web动画】SVG 实现复杂线条动画

    在上一篇文章中,我们初步实现了一些利用基本图形就能完成的线条动画: [Web动画]SVG 线条动画入门 当然,事物都是朝着熵增焓减的方向发展的,复杂线条也肯定比有序线条要多. 很多时候,我们无法人工去 ...

随机推荐

  1. Finding the Right EAV Attribute Table

    $customer = Mage::getModel('catalog/product'); $entity = $customer->getResource(); $attribute = M ...

  2. iptables初步接触

    0.iptables命令选项输入顺序:iptables -t 表名 <-A/I/D/R> 规则链名 [规则号] <-i/o 网卡名> -p 协议名 <-s 源IP/源子网 ...

  3. Redis取出中文乱码问题

    直接打开Redis客户端,如果存储了中文的内容,取出时会发生乱码: 解决办法很简单,打开客户端时加上 --raw,这样就可以了: 顺便说一下,-a后面跟的是密码,打码了,各位见谅!

  4. Privacy-Preserving Deep Learning via Additively Homomorphic Encryption

    郑重声明:原文参见标题,如有侵权,请联系作者,将会撤销发布! Full version of a paper at the 8-th International Conference on Appli ...

  5. CentOS 6.x/7.x上安装git

    yum安装 # yum info git # yum install -y git 可以通过下面的命令来检查是否安装了git环境 git --version 参考:如何在CentOS 6.x/7.x上 ...

  6. 牛客网PAT练兵场-旧键盘打字

    题目地址:https://www.nowcoder.com/pat/6/problem/4059 题解:用数组下标标记,直接模拟 /** * *作者:Ycute *时间:2019-12-01-21.3 ...

  7. webpack(从上篇博客中拿出来的)

    插件配置: emmet: vscode内置了这个,但是没有开启,要在设置里面"emmet.triggerExpansionOnTab": true, vscoed-icons插件: ...

  8. 从request中获取文件流的两种方式,配置文件上传大小

    原文地址:https://blog.csdn.net/xyr05288/article/details/80692132

  9. 用python导入20个G的json数据到Mysql数据库

    整体思路参考资料:https://blog.csdn.net/layman2016/article/details/79252499 作业:有一个16个G的跟疫情相关的json新闻大数据(articl ...

  10. Macos 编译运行调试Mysql源代码

    准备编译工具Clion 下载地址 工具是macos用的系统 百度云盘下载地址(密码: 7dus) 下载mysql源码 Mysql源码下载地址 下载boost boost下载地址 前期准备工作 MySQ ...