我有一个非常有趣的问题,当我将新的 SVG 元素添加到 div 时,只有第一次调用 append 时才会出现新的 svg 元素。它们在硬编码时工作,但是当它们被添加到 onmousedown 时,它们不会出现,即使它们被添加到 HTML 文件中。我假设这是我对 SVG 理解的问题,并且无法动态添加元素,但我一直在寻找互联网,并找不到任何关于该主题的内容。
你可以看到在 $(document).mousedown 函数中,一个新的圆圈被附加到了 svg holder 中,但是即使它被添加到了 SVG holder 中,它也不会显示在网页上。
代码:
HTML:
<div id="svgHolder">
<!--THIS CIRCLE SHOWS UP-->
<svg><circle cx='50' cy='50' r='40' stroke='black' stroke-width='1' fill='red' /></svg>
</div>
jQuery/JavaScript:
$(document).ready(function(){
var mouse={
x:0,
y:0,
drawing:false,
lastX:0,
lastY:0,
}
$(document).mousedown(function(e){
console.log('md')
mouse.x=e.clientX
mouse.y=e.clientY
mouse.drawing=true
//THIS CIRCLE WILL BE ADDED TO THE SVGHOLDER, BUT WILL NOT SHOW UP
$("#svgHolder").append("<svg><circle cx='"+mouse.x+"' cy='"+mouse.y+"' r='40' stroke='black' stroke-width='1' fill='red' /></svg>");
});
$(document).mouseup(function(e){
console.log('mu')
mouse.x=e.clientX
mouse.y=e.clientY
mouse.drawing=false
});
$(document).mousemove(function(e){
console.log('mm')
mouse.x=e.clientX
mouse.y=e.clientY
});
});