साथ संदर्भित मैं एक एसवीजी लोगो इसलिए की तरह एक प्रतीक के रूप में परिभाषित किया गया है:स्केल इनलाइन एसवीजी प्रतीक <use>
<svg class="SpriteSheet">
<symbol id="icon-logo" viewBox="-12 -79.61 407.19 108.36">
<path id="logo-upperLeft" d="M0-67.61l83.66 0 0-10 -93.66 0 0 30.92 10 0Z" transform="translate(-2 -2)"></path>
<path id="logo-upperRight" d="M383.19-67.61l-83.66 0 0-10 93.66 0 0 30.92 -10 0Z" transform="translate(2 -2)"></path>
<path id="logo-lowerLeft" d="M0 16.75l83.66 0 0 10 -93.66 0 0-30.92 10 0Z" transform="translate(-2 2)"></path>
<path id="logo-lowerRight" d="M383.19 16.75l-83.66 0 0 10 93.66 0 0-30.92 -10 0Z" transform="translate(2 2)"></path>
</symbol>
</svg>
इस परिभाषा body
के शीर्ष पर शामिल है और display:none
के साथ स्टाइल है।
दस्तावेज़ में बाद में, मैं इस तरह से लोगो का उपयोग करें:
.Header-logo {
height: 5rem;
}
यह इस में जो परिणाम:
<header class="Header">
<h1 class="Header-headline">
<a href="/">
<svg class="Header-logo">
<use xlink:href="#icon-logo"></use>
</svg>
</a>
</h1>
</header>
मैं एक स्वत: चौड़ाई के साथ, लोगो एक निश्चित ऊंचाई बनाना चाहते :
हालांकि ऊंचाई सही है (यहां, 1rem 24px है), चौड़ाई डिफ़ॉल्ट 300px बनी हुई है। width:auto
जोड़ना कोई बदलाव नहीं करता है। इस समस्या की खोज में, मैं कई संभावित समाधान here और here पर आया। हालांकि, मेरे आवेदन के साथ कोई भी काम नहीं कर रहा है: छवि के एक बड़े हिस्से को उपयोग में कटौती के बिंदु पर व्यूबॉक्स को दोबारा लागू करना और <img>
टैग का उपयोग करना संभव नहीं है क्योंकि मुझे स्टाइल उद्देश्यों के लिए एसवीजी के डीओएम तक पहुंच बनाए रखने की आवश्यकता है।
मैं छवि के ज्ञात पहलू अनुपात के आधार पर एक हार्ड-कोडित चौड़ाई जोड़ सकता हूं, लेकिन यह एक गैर-इष्टतम समाधान प्रतीत होता है: यदि भविष्य में लोगो का पहलू अनुपात बदलता है तो क्या होगा? एक और विकल्प width:100%
को परिभाषित करना है, जो काम करता है, हालांकि, यह <a>
के 'क्लिक करने योग्य' क्षेत्र को हेडर की पूरी चौड़ाई में विस्तारित करता है, जिसे मैं टालना चाहता हूं।
क्या <symbol>
परिभाषा में व्यूबॉक्स का वर्णन किया गया है, तो परिभाषित ऊंचाई के साथ स्वचालित रूप से आकार की चौड़ाई हो सकती है? क्या मुझे <img>
टैग या एसवीजी तत्व के लिए पूर्ण चौड़ाई का उपयोग करने के लिए रील किया जाना चाहिए?
निश्चित रूप से नहीं जवाब मैं खोज रहा था, लेकिन कम से कम यह एक समाधान प्रदान करता है! यह भी ध्यान देने के लिए धन्यवाद कि व्यूबॉक्स को 0 0' से शुरू होना चाहिए: व्यूबॉक्स को कॉपी करने के मेरे प्रयासों ने '-12 -79.61' मानों का उपयोग किया और छवि को आंशिक रूप से काट दिया। –
[इस] से संबंधित टिप्पणी धागा (http://stackoverflow.com/a/24828157/600882) उत्तर कुछ मुद्दों पर चर्चा करता है। –