为什么没有形状?

时间:2013-12-28 22:22:58

标签: javascript svg shape

我正在尝试学习SVG并拥有以下代码。单击的点打印正常,但没有创建形状。有人可以指出我做错了什么。

<?xml version='1.0' standalone='no'?>
<!DOCTYPE svg PUBLIC '-//W3C//DTD SVG 20001102//EN' 'http://www.w3.org/TR/2000/CR-SVG-20001102/DTD/svg-20001102.dtd'>
<svg width='100%' height='100%' xmlns='http://www.w3.org/2000/svg' onload='Init(evt)' onmousedown='Grab(evt)'  >

<title>Drag And Drop</title>


<script><![CDATA[
  var SVGDocument = null;
  var SVGRoot = null;

  var BackDrop = null;

  function Init(evt)
  {
     SVGDocument = evt.target.ownerDocument;
     SVGRoot = SVGDocument.documentElement;
     BackDrop = SVGDocument.getElementById('BackDrop');
  }

  function Grab(evt)
  {
     var targetElement = evt.target;
     if ( BackDrop == targetElement )
     {
        alert ( 'point: ' + evt.clientX + ' ' + evt.clientY);

        var c1 = SVGDocument.createElementNS("http://www.w3.org/2000/svg", "circle");
        c1.setAttribute("cx", evt.clientX);
        c1.setAttribute("cy", evt.clientY);
        c1.setAttribute("r", "100");
        c1.setAttribute("fill", "#336699");
        BackDrop.appendChild(c1);
    }
  };

]]></script>

<rect id='BackDrop' x='-10%' y='-10%' width='110%' height='110%' fill='none' pointer-events='all' />
</svg>

1 个答案:

答案 0 :(得分:2)

BackDrop是<rect>,而<rect>元素不是可以包含图形元素子元素的容器。如果您将圆圈创建为根元素的子元素,则改为

    BackDrop.appendChild(c1);

    SVGRoot.appendChild(c1);

将出现圆圈。