[英]Add a child node to an inline SVG with JavaScript. Imposible on IE9?
I just want add a new text node in a SVG on a html using accion() javaScript function: 我只想使用accion()javaScript函数在html上的SVG中添加一个新的文本节点:
<!DOCTYPE>
<html>
<body>
<head>
<script type="text/javascript">
function accion(){
var SVGDocument = document.getElementById("idSVG");
var text2 = SVGDocument.createTextNode("text");
SVGDocument.appendChild(text2);
}
</script>
</head>
<input type="button" onclick="accion()" value="GO!!"/>
<svg id="idSVG">
<text id="texto" x="50" y="35" font-size="14">PRUEBA</text>
</svg>
</body>
</html>
But SVGDocument.createTextNode("text");
但是SVGDocument.createTextNode("text");
return an error: Object does not support this property or method
. 返回错误: Object does not support this property or method
。 I think the problem is I can't get a correct reference to idSVG element. 我认为问题是我无法正确引用idSVG元素。 I'm using IE9. 我正在使用IE9。
The example below works for me. 以下示例适用于我。
Note that if you don't set ay co-ordinate the default 0, 0 is likely outside the svg bounding box. 请注意,如果未设置y坐标,则默认值为0,0可能位于svg边界框之外。
<!DOCTYPE>
<html>
<body>
<head>
<script type="text/javascript">
function accion(){
var svg = document.getElementById("idSVG");
var text2 = document.createElementNS("http://www.w3.org/2000/svg", "text");
text2.setAttribute("y", "100");
var textContent = document.createTextNode("this is the text content");
text2.appendChild(textContent);
svg.appendChild(text2);
}
</script>
</head>
<input type="button" onclick="accion()" value="GO!!"/>
<svg id="idSVG">
<text id="texto" x="50" y="35" font-size="14">PRUEBA</text>
</svg>
</body>
</html>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.