svg的学习
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的学习的更多相关文章
- SVG相关学习(一)SVG基础
SVG 相关学习 SVG SVG 指可伸缩矢量图形 (Scalable Vector Graphics) SVG viewBox <svg width="500" heigh ...
- SVG绘图学习总结
在我们平时做的很多网站项目中都会需要绘制各种各样的二维矢量图形.比如做城市地下管网的断面图.管线管点的坐标位置矢量标识图.钻孔位置或地层剖面图等等.我们有很多中方法来绘制这些矢量图(vml.canva ...
- JavaScript权威设计--jQuery,Ajax.animate,SVG(简要学习笔记二十)[完结篇]
1.$和jquery在全局命名空间中定义的唯一两个变量. 2.jquery是工厂函数,不是构造函数.他返回一个新创建的对象. 3.jquery的四种调用方式: <1>传递C ...
- svg动画学习
首先我们定义一块画布,然后在上面画一个圆形. 他看起来应该是这个样子的:(每一个实例我都会附加图片以及demo链接,方便直观的理解与源代码的查看,查看的时候请使用标准浏览器) 点击查看Demo 现在我 ...
- svg滤镜学习
SVG滤镜绝对称得上是他最强大的功能之一,在不影响任何文档结构的前提下,允许你给你的矢量图形添加各种专业视觉效果,我个人给他的定义就是,把PS装到了网页上. 一. SVG滤镜的原理 基本原理描述太多 ...
- SVG的学习(34—36)
使用js来动态绘制svg图片,首先就是要创建svg 节点. 使用createElementNS(),语法: document.createElementNS(namespaceURI, qualifi ...
- SVG图像学习
参考阮一峰老师: SVG 图像入门教程 基本使用 可以直接放入到html中 <body> <svg viewBox="0 0 800 600" > < ...
- d3 svg简单学习
矩形 <rect x="/> 圆形 <circle cx="/> 椭圆 <ellipse cx="/> 线 <line x1=& ...
- 【Web动画】SVG 实现复杂线条动画
在上一篇文章中,我们初步实现了一些利用基本图形就能完成的线条动画: [Web动画]SVG 线条动画入门 当然,事物都是朝着熵增焓减的方向发展的,复杂线条也肯定比有序线条要多. 很多时候,我们无法人工去 ...
随机推荐
- 归纳从文件中读取数据的六种方法-JAVA IO基础总结第2篇
在上一篇文章中,我为大家介绍了<5种创建文件并写入文件数据的方法>,本节我们为大家来介绍6种从文件中读取数据的方法. 另外为了方便大家理解,我为这一篇文章录制了对应的视频:总结java从文 ...
- 【免费】windows下如何生成tar.gz,一键生成tar.gz
废话 一.实验背景 tar.gz 是Linux和Unix下面比较常用的格式,一条命令就可以把文件压缩打包成tar.gz格式,然而这种格式在windows并不多见. Linxu服务器上,tar.gz 包 ...
- 【JDK】Linux安装源码包JDK完整步骤
[JDK]Linux安装源码包JDK完整步骤 1.检查一下系统中的jdk版本 [root@localhost software]# java -version 显示: openjdk version ...
- Redis锁实现防重复提交和并发问题
@Slf4j @Component public class RedisLock { public static final int LOCK_EXPIRE = 5000; @Autowired pr ...
- private protected internal public
//C#中的访问修饰符: //private,私有访问修饰符,被private访问修饰符修饰的成员只有在当前类的内部可以访问,其他地方一律不能访问[类中成员,如果不写访问修饰符则默认都是私有的] // ...
- Macbook Pro HDMI 无信号解决办法
因为CS:GO无法启动的问题,使用过了下面的命令 sudo pmset -a GPUSwitch 0 导致HDMI显示器无信号 输入下面的代码 sudo pmset -a GPUSwitch 1 可以 ...
- Forward Rendering VS Deferred Rendering
http://gad.qq.com/article/detail/32731 Forward Rendering Deferred Rendering
- php中的加密解密模块-mcrypt
<?php /* 打开加密算法和模式 */ $td = mcrypt_module_open('rijndael-256', '', 'ofb', ''); /* 创建初始向量,并且检测密钥长度 ...
- 2 http
response.write(string|buffer)可以调用0-n次 response.end(string|buffer) 方法.必须调用一次 response.setHeader('Con ...
- Spring 框架(持续完善中)
目录标题 一.Spring 框架 Spring 是什么? Spring Framework 核心概念 了解Spring 框架的架构图 二.Spring Framework 之 IOC 开发的步骤流程 ...