I tried the following:
<!DOCTYPE html>
<html>
<head>
<title>#002</title>
<meta charset="UTF-8">
<script src="//code.jquery.com/jquery-1.11.2.min.js"></script>
<script src="../../resurces/js/remove_element.js"></script>
<script>
$("document").ready(function(){
document.getElementById("other").addEventListener("click",function(){
console.log("fired");
var animation = document.createElementNS("http://www.w3.org/2000/svg", "animation");
animation.setAttribute("id","anim_1");
animation.setAttribute("attributeName","height");
animation.setAttribute("attributeType","XML");
animation.setAttribute("dur","3.75s");
animation.setAttribute("fill","freeze");
animation.setAttribute("from","0");
animation.setAttribute("to","100");
animation.setAttribute("begin","indefinite");
animation.setAttribute("end","indefinite");
document.getElementById("RectElement").appendChild(animation);
console.log(animation);
animation.beginElement(); //ref. http://www.w3.org/TR/SVG/animate.html#__smil__ElementTimeControl__beginElement
setTimeout(function(){
animation.remove();
console.log("cleared_animation");
},2500);
});
});
</script>
</head>
<body>
<svg width="20cm" height="20cm" viewBox="0 0 100 100"
xmlns="http://www.w3.org/2000/svg" version="1.1">
<rect id="other" x="0.5" y="0.5" width="98" height="98"
fill="none" stroke="blue" stroke-width="1" />
<rect id="RectElement" x="45" y="100" width="10" height="0"
fill="rgb(255,255,0)" transform="rotate(180, 50, 100)">
</rect>
</svg>
</body>
</html>
But Firefox keep telling me that "animation.beginElement is not a function" I used the examples from this answer, this one and the last one. I also looked it up on the w3 documentation.
Can someone tell me where my mistake is ?