运行代码,我们发现没有报错,也没有显示任何结果。
添加:alert(path),打印出 [object HTMLUnknownElement]。
说明 html 把 path 当作普通的 html 标签解析了,发现并不认识该标签,所以页面没有任何效果,此时我们需要介绍一个新的创建元素方法。
createElementNS介绍
createElementNS 是创建一个具有指定的命名空间URI和限定名称的元素。
使用语法:document.createElementNS(namespaceURI, qualifiedName[, options]);
-
namespaceURI 指定与元素相关联的命名空间URI的字符串。创建的元素的namespaceURI (en-US)属性使用namespaceURI的值进行初始化。
-
qualifiedName指定要创建的元素的类型的字符串。 创建的元素的nodeName (en-US)属性使用qualifiedName的值进行初始化。
-
options可选的一个可选的包含单个属性的ElementCreationOptions对象,其值是预先使用customElements.define()定义的自定义元素的标签名称。为了向后兼容自定义元素规范的早期版本,一些浏览器允许您在此使用字符串替代对象,其中字符串的值是自定义元素的标签名称。
生成path元素代码:
let path = document.createElementNS(
“http://www.w3.org/2000/svg”,
“path”
)
js操作属性时,html元素与SVG元素区别:
普通html元素可以使用两种方法:
-
setAttribute(x,val) / getAttribute(x)
-
obj.x
SVG操作方法只有一种
- setAttribute(x,val) / getAttribute(x)
eg3:图表中饼图是特别常见的,我们就先使用 js 动态地绘制一个扇形圆弧。
运行结果如图所示:
如果有兴趣,可以自己修改开始角度和结束角度,可以绘制出很多种不同效果的圆弧。
二、样式以及优先级
=========
上述代码
<path d="
M 0 100 //(0,100)是起点
L 100 100 // 画一条直接到 (100,100)
" stroke=“black” stroke-width=“1” fill=“none”>
上述属性可以分为两类:
-
只能为属性 - 决定图形或路径形状的
-
可以放样式 - 视觉上的效果
如 troke、fill等是控制视觉上的效果,这样的属性可以放入 style 样式中。所以上述代码可以改写为:
<path d="
M 0 100 //(0,100)是起点
L 100 100 // 画一条直接到 (100,100)
" style=“stroke:black;stroke-width:1;fill:none”>
该样式可以放到 head 的 style 中,代码为:
path{
fill:none;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
最后
大厂面试问深度,小厂面试问广度,如果有同学想进大厂深造一定要有一个方向精通的惊艳到面试官,还要平时遇到问题后思考一下问题的本质,找方法解决是一个方面,看到问题本质是另一个方面。还有大家一定要有目标,我在很久之前就想着以后一定要去大厂,然后默默努力,每天看一些大佬们的文章,总是觉得只有再学深入一点才有机会,所以才有恒心一直学下去。
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算
!**](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算