<div align="center"><img id="_aimg_29021" aid="29021" zoomfile="data/attachment/forum/201507/31/110127s121x1h11l2cx62a.jpg" src="data/attachment/forum/201507/31/110127s121x1h11l2cx62a.jpg" class="zoom" onclick="zoom(this, this.src, 0, 0, 0)" style="max-width:90%" alt="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" title="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" w="640"></div> <br> <font size="3"> <strong>SVG DEFS元素</strong></font><br> <br> <font size="3"> SVG的<defs>元素用于预定义一个元素使其能够在SVG图像中重复使用。例如你可以将一些图形制作为一个组,并用</defs></font><font size="3"><defs></defs></font><font size="3">元素来定义它,然后你就可以在SVG图像中将它当做简单图形来重复使用。看下面的例子:</font><br> <div class="blockcode"> <div id="code_Ln4"><ol> <li><svg xmlns="http://www.w3.org/2000/svg"><br> </svg></li> <li> <defs><br> </defs> </li> <li> <g><br> </g> </li> <li> <rect x="100" y="100" width="100" height="100"></rect><br> </li> <li> <circle cx="100" cy="100" r="100"></circle><br> </li> <li> <br> </li> <li> <br> </li> <li> </li> </ol></div> <em onclick="copycode($('code_Ln4'));">复制代码</em> </div> <br> <font size="3"> 在<defs>元素中定义的图形不会直接显示在SVG图像上。要显示它们需要使用<use>元素来引入它们。如下面的代码所示:</use></defs></font><br> <div class="blockcode"> <div id="code_LfT"><ol> <li><svg xmlns="http://www.w3.org/2000/svg"> <br> </svg></li> <li> <defs><br> </defs> </li> <li> <g id="shape"><br> </g> </li> <li> <rect x="50" y="50" width="50" height="50"></rect><br> </li> <li> <circle cx="50" cy="50" r="50"></circle><br> </li> <li> <br> </li> <li> <br> </li> <li> <br> </li> <li> <use xlink:href="#shape" x="50" y="50"></use><br> </li> <li> <use xlink:href="#shape" x="200" y="50"></use> <br> </li> <li> </li> </ol></div> <em onclick="copycode($('code_LfT'));">复制代码</em> </div> <br> <font size="3"> 要引用<g>元素,必须在<g>元素上设置一个ID,通过ID来引用它。<use>元素通过xlink:href属性来引入<g>元素。注意在ID前面要添加一个#。</g></use></g></g></font><font size="3"><br> </font><br> <font size="3"> 在<use>元素中,通过x和y属性来指定重用图形的显示位置。注意在<g>元素中的图形的定位点都是0,0,在使用<use>元素来引用它的时候,它的定位点被转换为<use>元素x和y属性指定的位置。</use></use></g></use></font><br> <br> <font size="3"> 下面是上面代码的返回结果:</font><br> <img id="_aimg_29022" aid="29022" zoomfile="data/attachment/forum/201507/31/110350ligipy34bv2cbkySVG基础|SVG DEFS元素、SYMBOL元素和USE元素" src="data/attachment/forum/201507/31/110350ligipy34bv2cbkySVG%E5%9F%BA%E7%A1%80%7CSVG%20DEFS%E5%85%83%E7%B4%A0%E3%80%81SYMBOL%E5%85%83%E7%B4%A0%E5%92%8CUSE%E5%85%83%E7%B4%A0" class="zoom" onclick="zoom(this, this.src, 0, 0, 0)" style="max-width:90%" alt="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" title="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" w="299"><br> <font size="3"> 上面SVG图像中绿色的圆点并不是示例代码的一部分。它们是用来显示2个<use>元素的x和y坐标的。</use></font><br> <br> <font size="3"> 哪些元素可以被定义为defs中的元素呢?</font><br> <br> <font size="3"> 你可以将下面的元素放入到<defs>元素中使用:</defs></font><br> <br> <ul> <li><font size="3"> 任何图形元素,如:rect,line等</font></li> <li><font size="3"> g</font></li> <li> <font size="3"> symbol</font><br> </li> </ul> <br> <font size="3"> <strong> SVG SYMBOL元素</strong></font><br> <br> <font size="3"> SVG <symbol>元素用于定义可重复使用的符号。嵌入在<symbol>元素中的图形是不会被直接显示的,除非你使用<use>元素来引用它。</use></symbol></symbol></font><br> <br> <font size="3"> 下面是一个使用<symbol>元素的简单例子:</symbol></font><br> <div class="blockcode"> <div id="code_hnC"><ol> <li><svg xmlns="http://www.w3.org/2000/svg" width="500" height="100"><br> </svg></li> <li> <symbol id="shape2"><br> </symbol> </li> <li> <circle cx="25" cy="25" r="25" style="fill:#bf55ec;"></circle><br> </li> <li> <br> </li> <li> <br> </li> <li> <use xlink:href="#shape2" x="50" y="25"></use><br> </li> <li> </li> </ol></div> <em onclick="copycode($('code_hnC'));">复制代码</em> </div> <br> <font size="3"> </font><font size="3"><symbol></symbol></font><font size="3">元素需要一个ID号,以便以被<use>元素引用。</use></font><br> <img id="_aimg_29023" aid="29023" zoomfile="data/attachment/forum/201507/31/110351laklqklfyynilzqz.jpg" src="data/attachment/forum/201507/31/110351laklqklfyynilzqz.jpg" class="zoom" onclick="zoom(this, this.src, 0, 0, 0)" style="max-width:90%" alt="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" title="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" w="230"><br> <font size="3"> 一个</font><font size="3"><symbol></symbol></font><font size="3">元素可以有preserveAspectRatio和viewBox属性。而<g>元素不能拥有这些属性。因此相比于在<defs>元素中使用<g>的方式来复用图形,使用</g></defs></g></font><font size="3"><symbol></symbol></font><font size="3">元素也许是一个更好的选择。</font><br> <font size="3"><br> </font><br> <font size="3"> <strong>SVG USE元素</strong></font><br> <br> <font size="3"> SVG <use>元素可以在SVG图像中多次重用一个预定义的SVG图形,包括<g>元素和<symbol>元素。被重用的图形可以在定义<defs>的内部(图形将不可见直到使用use来引用它)或外部。</defs></symbol></g></use></font><br> <br> <font size="3"> 下面是一个使用<use>元素的例子:</use></font><br> <div class="blockcode"> <div id="code_mK3"><ol> <li><svg><br> </svg></li> <li> <defs><br> </defs> </li> <li> <g id="shape"><br> </g> </li> <li> <rect x="50" y="50" width="50" height="50"></rect><br> </li> <li> <circle cx="50" cy="50" r="50"></circle><br> </li> <li> <br> </li> <li> <br> </li> <li> <br> </li> <li> <use xlink:href="#shape" x="50" y="50"></use><br> </li> <li> <use xlink:href="#shape" x="200" y="50"></use><br> </li> <li> <br> </li> <li> </li> </ol></div> <em onclick="copycode($('code_mK3'));">复制代码</em> </div> <font size="3"> 上面的例子显示的是在<defs>元素中定义的<g>元素。</g></defs></font><br> <br> <font size="3"> 要引用<g>元素,必须给它一个ID号,通过ID号来引用它。</g></font><br> <br> <font size="3"> 下面是上面代码的返回结果:</font><br> <img id="_aimg_29024" aid="29024" zoomfile="data/attachment/forum/201507/31/110351dcrjgjjuwwoujbg0.jpg" src="data/attachment/forum/201507/31/110351dcrjgjjuwwoujbg0.jpg" class="zoom" onclick="zoom(this, this.src, 0, 0, 0)" style="max-width:90%" alt="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" title="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" w="285"><br> <font size="3"> 我们也可以引用不在<defs>元素中的图形。<use>元素可以引用SCG图像中的任何元素,只要这个元素有一个唯一的ID号,例如:</use></defs></font><br> <div class="blockcode"> <div id="code_you"><ol> <li><svg width="500" height="110"><br> </svg></li> <li> <br> </li> <li> <g id="shape2"><br> </g> </li> <li> <rect x="0" y="0" width="50" height="50"></rect><br> </li> <li> <br> </li> <li> <br> </li> <li> <use xlink:href="#shape2" x="200" y="50"></use><br> </li> <li> <br> </li> <li> </li> </ol></div> <em onclick="copycode($('code_you'));">复制代码</em> </div> <br> <font size="3"> 这个例子在<g>元素中定义了一个<rect>元素。然后通过<use>元素来引用这个<g>元素。它返回的结果如下面所示:</g></use></rect></g></font><br> <img id="_aimg_29025" aid="29025" zoomfile="data/attachment/forum/201507/31/110352hsuuusuur0oo8u0p.jpg" src="data/attachment/forum/201507/31/110352hsuuusuur0oo8u0p.jpg" class="zoom" onclick="zoom(this, this.src, 0, 0, 0)" style="max-width:90%" alt="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" title="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" w="296"><br> <font size="3"> 注意这里原始图形和复用的图形都会被显示。因为原始的图形并没有定义在<defs>或<symbol>元素中。所以它是可见的。</symbol></defs></font><br> <br> <font size="3"> 你可以为引用的图形设置CSS样式。你可以在<use>元素中使用style属性来为复用的图形设置它的样式。例如:</use></font><br> <div class="blockcode"> <div id="code_jj6"><ol> <li><svg width="500" height="110"><br> </svg></li> <li> <br> </li> <li> <g id="shape3"><br> </g> </li> <li> <rect x="0" y="0" width="50" height="50"></rect><br> </li> <li> <br> </li> <li> <br> </li> <li> <use xlink:href="#shape3" x="100" y="50" style="fill: #00ff00;"></use><br> </li> <li> <use xlink:href="#shape3" x="200" y="50" style="stroke: #00ff00; fill: none;"></use><br> </li> <li> <br> </li> <li> </li> </ol></div> <em onclick="copycode($('code_jj6'));">复制代码</em> </div> <br> <font size="3"> 注意上面的代码中,原始的图形并没有设置样式,它将是默认的样式(黑色)。</font><br> <img id="_aimg_29026" aid="29026" zoomfile="data/attachment/forum/201507/31/110353jii708bcnqimzmaf.jpg" src="data/attachment/forum/201507/31/110353jii708bcnqimzmaf.jpg" class="zoom" onclick="zoom(this, this.src, 0, 0, 0)" style="max-width:90%" alt="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" title="SVG基础|SVG DEFS元素、SYMBOL元素和USE元素" w="299"><br> <font size="3"> </font><font size="2"><font color="#808080">本文版权属于jQuery之家,转载请注明出处:<a href="http://www.htmleaf.com/ziliaoku/qianduanjiaocheng/201506132029.html" target="_blank">http://www.htmleaf.com/ziliaoku/ ... g/201506132029.html</a></font></font><br> <br>