我正在嘗試使用JavaScript(velocity.js)來設(shè)置一個SVG的動畫,這個SVG是我用<defs>
定義的,然后用<use>
實例化的,我在訪問要修改的SVG組件的DOM元素時遇到了問題。我的代碼與普通的內(nèi)聯(lián)SVG配合得很好,但是當(dāng)我切換到<defs>
/<use>
方法時,它就會中斷。
當(dāng)我使用內(nèi)聯(lián)SVG時,我可以console.log
有問題的元素,它會返回信息,但是嘗試訪問用<use>
生成的相同元素會返回一個空對象。在嘗試訪問用<use>
生成的SVG的DOM元素時,有什么特別需要我做的嗎?
The HTML
<div class="screen">
<svg>
<use href="/media/defs.svg#poppyIdle"></use>
</svg>
</div>
defs.svg(由inkscape生成,我所做的只是添加了<defs>
和<symbol>
)(不想發(fā)布全部內(nèi)容)
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:xlink="http://www.w3.org/1999/xlink"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape">
<defs>
<symbol id="poppyIdle" viewBox="0 0 140 250">
<metadata
id="metadata5">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<g
inkscape:groupmode="layer"
id="layer12"
inkscape:label="eyelids"
style="display:inline"
transform="translate(-6.125676,0.02323548)">
<rect
style="fill:#4d4d4d;fill-opacity:1;stroke-width:0.0694716"
id="rect942-3"
width="28.423023"
height="2.0695279"
x="34.666679"
y="34.632057" />
<rect
style="display:inline;fill:#4d4d4d;fill-opacity:1;stroke-width:0.0694716"
id="rect942-3-6"
width="28.423023"
height="2.0695279"
x="85.931053"
y="34.629658" />
</g>
</symbol>
</defs>
</svg>
SVG use元素類似于HTML中的shadowdom元素。只有USE元素本身的屬性是通過svgdom公開的-不能更改從原始符號克隆的單個USE元素實例上的任何屬性。它不像宏。