admin管理员组文章数量:1345407
I have a SVG document where three circles are drawn:
<?xml version="1.0"?>
<svg width="450" height="80" xmlns="">
<script>
document.fillCircle = function(id) {
var circles = document.getElementsByTagName('circle'),
circle = document.getElementById(id);
[].forEach.call(circles, function(circle) {
circle.setAttribute('fill','#ffffff');
});
circle.setAttribute('fill', '#000000');
}
</script>
<g>
<line y1="35" x1="35" y2="35" x2="375" stroke-width="3" stroke="#000000"/>
<circle id="state1" r="30" cy="35" cx="35" stroke-width="3" stroke="#000000" fill="#ffffff" onclick="fillCircle(this.id);"/>
<circle id="state2" r="30" cy="35" cx="205" stroke-width="3" stroke="#000000" fill="#ffffff" onclick="fillCircle(this.id);"/>
<circle id="state3" r="30" cy="35" cx="375" stroke-width="3" stroke="#000000" fill="#ffffff" onclick="fillCircle(this.id);"/>
</g>
</svg>
For testing purposes I have the onclick=""
method, but actually this document is an object in my html document:
<object id="test" data="test-vector.svg" width="100px" height="100px"></object>
I have a dataset and these three circles show the "progress" of every item. I regularly update the JSON set by pulling the new list from the server. For every item changed, I want to update the filled circle.
I would like to update the svg based on some javascript. However, I can't make it to get into the DOM of the SVG. I do not really care if the fillCircle()
is inside the svg or not and if I have to use <embed>
, <object>
or something else, but this kind of javascript does not work for me.
<html>
<body>
<object id="test" data="test-vector.svg"></object>
<script>
var svg = document.getElementById('test');
console.log(svg);
svg.fillCircle('state2');
</script>
</body>
</html>
I tried several things I found on SO, like this one and this one, but whatever I test, the exception is always:
Uncaught TypeError: Object #<HTMLObjectElement> has no method 'fillCircle'
I have a SVG document where three circles are drawn:
<?xml version="1.0"?>
<svg width="450" height="80" xmlns="http://www.w3/2000/svg">
<script>
document.fillCircle = function(id) {
var circles = document.getElementsByTagName('circle'),
circle = document.getElementById(id);
[].forEach.call(circles, function(circle) {
circle.setAttribute('fill','#ffffff');
});
circle.setAttribute('fill', '#000000');
}
</script>
<g>
<line y1="35" x1="35" y2="35" x2="375" stroke-width="3" stroke="#000000"/>
<circle id="state1" r="30" cy="35" cx="35" stroke-width="3" stroke="#000000" fill="#ffffff" onclick="fillCircle(this.id);"/>
<circle id="state2" r="30" cy="35" cx="205" stroke-width="3" stroke="#000000" fill="#ffffff" onclick="fillCircle(this.id);"/>
<circle id="state3" r="30" cy="35" cx="375" stroke-width="3" stroke="#000000" fill="#ffffff" onclick="fillCircle(this.id);"/>
</g>
</svg>
For testing purposes I have the onclick=""
method, but actually this document is an object in my html document:
<object id="test" data="test-vector.svg" width="100px" height="100px"></object>
I have a dataset and these three circles show the "progress" of every item. I regularly update the JSON set by pulling the new list from the server. For every item changed, I want to update the filled circle.
I would like to update the svg based on some javascript. However, I can't make it to get into the DOM of the SVG. I do not really care if the fillCircle()
is inside the svg or not and if I have to use <embed>
, <object>
or something else, but this kind of javascript does not work for me.
<html>
<body>
<object id="test" data="test-vector.svg"></object>
<script>
var svg = document.getElementById('test');
console.log(svg);
svg.fillCircle('state2');
</script>
</body>
</html>
I tried several things I found on SO, like this one and this one, but whatever I test, the exception is always:
Uncaught TypeError: Object #<HTMLObjectElement> has no method 'fillCircle'
Share
Improve this question
edited May 23, 2017 at 12:33
CommunityBot
11 silver badge
asked Oct 8, 2012 at 14:55
Jurian SluimanJurian Sluiman
13.6k3 gold badges69 silver badges101 bronze badges
2 Answers
Reset to default 8var object = document.getElementById("test")
will get you the object element but you can't call that till the object has loaded. Once you have that you can use object.contentDocument to do things with the embedded svg document.
<html>
<body>
<object id="test" data="test-vector.svg" onload="f()" ></object>
<script>
function f() {
var svg = document.getElementById('test');
svg.contentDocument.fillCircle('state2');
}
</script>
</body>
</html>
Why don't you embed the SVG directly in your HTML code (using SVG tags)? According to W3, this works in all modern browsers (and IE >= 9). Accessing and changing the circles' properties with JS is then trivial...
<html>
<body>
<svg>...</svg>
</body>
</html>
If you want to keep your HTML/SVG structure though, you can do the following:
var svg = document.getElementById("test");
svg.onload = function(){
svg.contentDocument.fillCircle("state2");
};
The trick is to wait for the SVG object to load (onload
event); not till then you can safely use the contentDocument
property. Btw, this is also described in this solution on SO (you posted a link to it). ;)
本文标签: Call svg javascript function inside html javascript functionStack Overflow
版权声明:本文标题:Call svg javascript function inside html javascript function - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743731460a2529255.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论