我怎么能解决这个问题嵌入JS在SVG?



如何将JS正确嵌入SVG?我想做一个时钟,我想在CSS,但JS的作品。这是我的代码:

<svg version="1.1" width="200" height="200" display="block" tranform="translate(-50%,-50%)" xmlns="https://www.w3.org/2000/svg">
<filter id="innerShadow" x="-20%" y="-20%" width="140%" height="140%">
<feGaussianBlur in="SourceGraphic" stdDeviation="3" result="blur" />
<feOffset in="blur" dx="2.5" dy="2.5" />
</filter>
<g>
<circle
id="shadow"
style="fill:rgba(0,0,0,.1)"
cx="97"
cy="100"
r="87"
filter="url(#innerShadow)"
></circle>
<circle
id="circle"
style="stroke:#fff;stroke-width:12px;fill:#20b7af"
cx="100"
cy="100"
r="80"
></circle>
</g>
<g>
<line
x1="100"
y1="100"
x2="100"
y2="55"
transform="rotate(80 100 100)"
style="stroke-width:3px;stroke:#fffbf9"
id="hourhand"
>
<animatetransform
attributeName="transform"
attributeType="XML"
type="rotate"
dur="43200s"
repeatCount="indefinite"
/>
</line>
<line
x1="100"
y1="100"
x2="100"
y2="40"
style="stroke-width:4px;stroke:#fdfdfd"
id="minutehand"
>
<animatetransform
attributeName="transform"
attributeType="XML"
type="rotate"
dur="3600s"
repeatCount="indefinite"
/>
</line>
<line
x1="100"
y1="100"
x2="100"
y2="30"
style="stroke-width:2px;stroke:#c1efed"
id="secondhand"
>
<animatetransform
attributeName="transform"
attributeType="XML"
type="rotate"
dur="60s"
repeatCount="indefinite"
/>
</line>
</g>
<circle
id="center"
style="fill:#128a86;stroke:#c1efed;stroke-width:2px"
cx="100"
cy="100"
r="3"
></circle>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(30 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(60 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(90 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(120 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(150 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(180 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(210 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(240 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(270 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(300 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(330 100 100)" stroke="#ffffff"></line>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(360 100 100)" stroke="#ffffff"></line>
<script type="text/javascript">
var hands = [];
hands.push(document.querySelector('#secondhand > *'));
hands.push(document.querySelector('#minutehand > *'));
hands.push(document.querySelector('#hourhand > *'));

function shifter(val) {
return [val, 100, 100].join(' ');
}

var date = new Date();
var hoursAngle = 360 * date.getHours() / 12 + date.getMinutes() / 2;
var minuteAngle = 360 * date.getMinutes() / 60;
var secAngle = 360 * date.getSeconds() / 60;
hands[0].setAttribute('from', shifter(secAngle));
hands[0].setAttribute('to', shifter(secAngle + 360));
hands[1].setAttribute('from', shifter(minuteAngle));
hands[1].setAttribute('to', shifter(minuteAngle + 360));
hands[2].setAttribute('from', shifter(hoursAngle));
hands[2].setAttribute('to', shifter(hoursAngle + 360));
</script>
</svg>

如果这是不可能的我理解,但我想要一个解决方案。我正在跑步。当我打开它时,它给出了这个XML文档树

This XML file does not appear to have any style information associated with it. The document tree is shown below.
<svg xmlns="https://www.w3.org/2000/svg" version="1.1" width="200" height="200" display="block" tranform="translate(-50%,-50%)">
<filter id="innerShadow" x="-20%" y="-20%" width="140%" height="140%">
<feGaussianBlur in="SourceGraphic" stdDeviation="3" result="blur"/>
<feOffset in="blur" dx="2.5" dy="2.5"/>
</filter>
<g>
<circle id="shadow" style="fill:rgba(0,0,0,.1)" cx="97" cy="100" r="87" filter="url(#innerShadow)"/>
<circle id="circle" style="stroke:#fff;stroke-width:12px;fill:#20b7af" cx="100" cy="100" r="80"/>
</g>
<g>
<line x1="100" y1="100" x2="100" y2="55" transform="rotate(80 100 100)" style="stroke-width:3px;stroke:#fffbf9" id="hourhand">
<animatetransform attributeName="transform" attributeType="XML" type="rotate" dur="43200s" repeatCount="indefinite"/>
</line>
<line x1="100" y1="100" x2="100" y2="40" style="stroke-width:4px;stroke:#fdfdfd" id="minutehand">
<animatetransform attributeName="transform" attributeType="XML" type="rotate" dur="3600s" repeatCount="indefinite"/>
</line>
<line x1="100" y1="100" x2="100" y2="30" style="stroke-width:2px;stroke:#c1efed" id="secondhand">
<animatetransform attributeName="transform" attributeType="XML" type="rotate" dur="60s" repeatCount="indefinite"/>
</line>
</g>
<circle id="center" style="fill:#128a86;stroke:#c1efed;stroke-width:2px" cx="100" cy="100" r="3"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(30 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(60 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(90 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(120 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(150 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(180 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(210 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(240 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(270 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(300 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(330 100 100)" stroke="#ffffff"/>
<line x1="100" y1="20" x2="100" y2="40" transform="rotate(360 100 100)" stroke="#ffffff"/>
<script type="text/javascript"> var hands = []; hands.push(document.querySelector('#secondhand > *')); hands.push(document.querySelector('#minutehand > *')); hands.push(document.querySelector('#hourhand > *')); function shifter(val) { return [val, 100, 100].join(' '); } var date = new Date(); var hoursAngle = 360 * date.getHours() / 12 + date.getMinutes() / 2; var minuteAngle = 360 * date.getMinutes() / 60; var secAngle = 360 * date.getSeconds() / 60; hands[0].setAttribute('from', shifter(secAngle)); hands[0].setAttribute('to', shifter(secAngle + 360)); hands[1].setAttribute('from', shifter(minuteAngle)); hands[1].setAttribute('to', shifter(minuteAngle + 360)); hands[2].setAttribute('from', shifter(hoursAngle)); hands[2].setAttribute('to', shifter(hoursAngle + 360)); </script>
</svg>

如果我添加!CDATA[[script]],它只是给出一个简单的错误。就像在x行检测到错误一样

SVG文件可以链接到JavaScript文件,也可以在script元素中包含JavaScript。在后一种情况下,既然SVG是XML,您需要将所有JS代码放在CDATA元素中。在<![CDATA[]]>前面有//,因为这两个标签不是JavaScript,但它仍然是有效的XML。

<?xml version="1.0" encoding="UTF-8"?>
<svg viewBox="0 0 200 200" xmlns="http://www.w3.org/2000/svg">
<filter height="140%" id="innerShadow" width="140%" x="-20%" y="-20%">
<feGaussianBlur in="SourceGraphic" result="blur" stdDeviation="3"/>
<feOffset dx="2.5" dy="2.5" in="blur"/>
</filter>
<g>
<circle cx="97" cy="100" filter="url(#innerShadow)" id="shadow" r="87" style="fill:rgba(0,0,0,.1)"/>
<circle cx="100" cy="100" id="circle" r="80" style="stroke:#fff;stroke-width:12px;fill:#20b7af"/>
</g>
<g>
<line id="hourhand" style="stroke-width:3px;stroke:#fffbf9" transform="rotate(80 100 100)" x1="100" x2="100" y1="100" y2="55">
<animateTransform attributeName="transform" attributeType="XML" dur="43200s" repeatCount="indefinite" type="rotate"/>
</line>
<line id="minutehand" style="stroke-width:4px;stroke:#fdfdfd" x1="100" x2="100" y1="100" y2="40">
<animateTransform attributeName="transform" attributeType="XML" dur="3600s" repeatCount="indefinite" type="rotate"/>
</line>
<line id="secondhand" style="stroke-width:2px;stroke:#c1efed" x1="100" x2="100" y1="100" y2="30">
<animateTransform attributeName="transform" attributeType="XML" dur="60s" repeatCount="indefinite" type="rotate"/>
</line>
</g>
<circle cx="100" cy="100" id="center" r="3" style="fill:#128a86;stroke:#c1efed;stroke-width:2px"/>
<line stroke="#ffffff" transform="rotate(30 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(60 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(90 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(120 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(150 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(180 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(210 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(240 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(270 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(300 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(330 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<line stroke="#ffffff" transform="rotate(360 100 100)" x1="100" x2="100" y1="20" y2="40"/>
<script type="text/javascript">
//<![CDATA[
var hands = [];
console.log(hands);
hands.push(document.querySelector('#secondhand >*'));
hands.push(document.querySelector('#minutehand >*'));
hands.push(document.querySelector('#hourhand >*'));

function shifter(val) {
return [val, 100, 100].join(' ');
}

var date = new Date();
var hoursAngle = 360 * date.getHours() / 12 + date.getMinutes() / 2;
var minuteAngle = 360 * date.getMinutes() / 60;
var secAngle = 360 * date.getSeconds() / 60;
hands[0].setAttribute('from', shifter(secAngle));
hands[0].setAttribute('to', shifter(secAngle + 360));
hands[1].setAttribute('from', shifter(minuteAngle));
hands[1].setAttribute('to', shifter(minuteAngle + 360));
hands[2].setAttribute('from', shifter(hoursAngle));
hands[2].setAttribute('to', shifter(hoursAngle + 360));
//]]></script>
</svg>

显示时钟既可以作为HTML中的嵌入代码,也可以作为对SVG文件的引用。在后一种情况下,您需要在HTML中使用object或embed元素。如果你需要JS代码来运行,你就不能在CSS或img元素中引用SVG文件……在这里,我使用与上面完全相同的代码创建了一个具有数据URI的对象元素(因为我不能在ST上引用真正的文件):

<object width="200" height="200" data=""></object>

相关内容

  • 没有找到相关文章

最新更新