javascript – 如何操作SVG DOM并创建元素?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 如何操作SVG DOM并创建元素?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1820字,纯文字阅读大概需要3分钟。
内容图文
![javascript – 如何操作SVG DOM并创建元素?](/upload/InfoBanner/zyjiaocheng/808/b4e966caa5464a6a801f6974d148c9c2.jpg)
如何获取SVG DOM根目录,并以编程方式开始向其添加子项,而不是通过标记添加SVG元素?
解决方法:
<svg xmlns="http://www.w3.org/2000/svg">
<script>
var svg = document.documentElement;
var svgNS = svg.namespaceURI;
var circle = document.createElementNS(svgNS,'circle');
circle.setAttribute('cx',100);
circle.setAttribute('cy',200);
circle.setAttribute('r',50);
circle.setAttribute('fill','red');
circle.setAttribute('stroke','black');
circle.setAttribute('stroke-width','20px');
circle.setAttribute('stroke-opacity','0.5');
svg.appendChild(circle);
</script>
</svg>
见于行动:http://phrogz.net/SVG/create-circle.svg
因为发出所有这些setAttribute调用会非常麻烦,所以我经常使用这样的函数:
// Create an SVG element on another node with a set of attributes.
// Attributes with colons in the name (e.g. 'xlink:href') will automatically
// find the appropriate namespace URI from the SVG element.
// Optionally specify text to create as a child node, for example
// createOn(someGroup,'text',{x:100,'text-anchor':'middle'},"Hello World!");
function createOn(root,name,attrs,text){
var doc = root.ownerDocument, svg = root;
while (svg.tagName!='svg') svg = svg.parentNode;
var el = doc.createElementNS(svg.namespaceURI,name);
for (var a in attrs){
if (!attrs.hasOwnProperty(a)) continue;
var p = a.split(':');
if (p[1]) el.setAttributeNS(svg.getAttribute('xmlns:'+p[0]),p[1],attrs[a]);
else el.setAttribute(a,attrs[a]);
}
if (text) el.appendChild(doc.createTextNode(text));
return root.appendChild(el);
}
在行动中,上述文件变得更加简单:
<svg version="1.1" baseProfile="full" xmlns="http://www.w3.org/2000/svg">
<script>
var svg = document.documentElement;
createOn(svg,'circle',{
cx:100, cy:200, r:50,
fill:'red', stroke:'black',
'stroke-width':'20px', 'stroke-opacity':0.5
});
// …function from above…
</script>
</svg>
见于行动:http://phrogz.net/svg/create-circle-2.svg
内容总结
以上是互联网集市为您收集整理的javascript – 如何操作SVG DOM并创建元素?全部内容,希望文章能够帮你解决javascript – 如何操作SVG DOM并创建元素?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。