What is an SVG File and how can it be embeded?
In 1998, the World Wide Web Consortium (W3C) proposed two potential candidates for a new standard markup language to create two-dimensional vector graphics based on XML. Microsoft and Macromedia (today known as Adobe Systems) entered the vector markup language (VML) into the race, while IBM and Adobe among others offered up the precision graphics markup language (PGML). In the end, the W3C decided to adopt neither of the two languages as a standard and instead merge the two. On September 4, 2001, the result was published in a recommendation called Scalable Vector Graphics (SVG) 1.0 Specification. However, this approach made it impossible for the W3C to satisfy all the stakeholders, and so Microsoft continued to rely on its own language – VML – for a long time in its applications (such as Internet Explorer, versions 1 through 9). This, however, did not stop the newly introduced SVG format from becoming a great success.
¿Qué es SVG?
Por aquel entonces, cuando el W3C convirtió a los Scalable Vector Graphics en una especificación recomendada para escribir gráficos vectoriales bidimensionales, el lenguaje XML ya era considerado la mejor solución para este tipo de gráficos, incluso en su forma animada. Así, como los navegadores aún no estaban preparados para el formato SVG o, como en el caso de IE, se oponían a él, era imprescindible usar plugins externos como el Adobe SVG Viewer o el Batik SVG Toolkit de Apache para poder leer y representar los gráficos escritos en XML. En caso contrario, los webmasters tenían que recurrir al formato PNG como solución alternativa.
Estas medidas ya no son necesarias hoy en día porque todos los navegadores soportan HTML5, un lenguaje que contiene un intérprete que permite insertar elementos SVG en el código HTML directamente sin tener que añadir el espacio de nombres de XML, que es el que informa al navegador del contexto del elemento que se ha insertado. Con ello también desaparece la necesidad de un intérprete específico como el que contienen los plugins que se han mencionado arriba.
A diferencia de los gráficos de píxeles, el formato SVG se caracteriza porque define los objetos gráficos de una imagen desde un punto de vista matemático y no encuadrándolos en una rejilla de píxeles. Esto hace que se puedan escalar formas geométricas, iconos, dibujos técnicos, fuentes tipográficas y logos sin pérdidas de calidad y sin mostrar el efecto de escalera tan típico de las imágenes de píxeles. Si quieres profundizar en las diferencias entre un formato y otro lee nuestra guía sobre imágenes vectoriales y de píxeles.
The advantages of using the SVG format
With the continued development of internet browsers, it is increasingly commonplace to see SVG used in HTML documents, with responsive web design also playing an important role. Vector graphics’ main strength lies in their scalability in the design of web projects across multiple devices and displays. This is just one of the many good reasons to use SVG file formats when designing your website. Other benefits include:
- Small file size: aside from their complexity, SVG graphics are characterized by their very small file size, even when the graphics are enlarged. These image files thus provide a stable and fast performance regardless of the devices used. This results in shorter loading times, which in turn has a positive effect on the search engine ranking.
- Open source: the W3C has created SVG as a free standard, which means that you can use the award language without restriction, across multiple platforms and in combination with other XML languages.
- SVG files can be formatted with CSS: graphics in SVG format can be manipulated with the CSS stylesheet language. This allows all presentation attributes (i.e. colors, filters, font, font size) to be displayed in a separate CSS file or straight into the SVG in order to change the appearance of the graphic.
- High compatibility: the functions of the different parsers vary, but this has very little effect on the rendering of the graphics since the SVG format is both downward and upward compatible. As a result, browsers display images according to their own settings and ignore unknown XML elements without having any serious impact on the display.
- Barrier-free: SVG graphics are text-based and therefore machine-readable by screen readers and all devices that can understand and playback source code.
- Visible in source text: if the SVG graphic is in the HTML document, you can easily adjust it in the program editor and change options such as the font color or size without any detours.
The disadvantages of using the SVG format
The abovementioned benefits make embedding the SVG format indispensable for webmasters. The many complications related to the different browser settings are now a thing of the past. The graphics format offers advantages in usability, SEO, accessibility, etc. But is it too good to be true? The SVG format does come with its fair share of problems.
One crucial disadvantage associated with vector graphics is the limited range of programs. While you can choose from the usual image processing tools, you will need specific tools such as Adobe Illustrator or Inkscape in order to create, save, and convert SVG files. Consequently, getting to grips with SVG graphics can prove complex and time-intensive. Furthermore, the graphic language has been criticized for the following reasons:
- High demand on the client’s resources: HTML5 eliminated the problem of having to download plugins but moved the rendering process to the browser level. Unburdening the server and small file sizes may result in shorter loading times, but this supposed advantage also comes with problems. If the user’s computer doesn’t have the required processing power, complex vector graphics in the SVG format could lead to a delay in displaying the page. You can address this issue by removing unnecessary items to optimize the SVG code.
- Limited application possibilities: with its underlying technology, SVG is now the measure of all things when it comes to designing and scaling simple graphics and logos. By contrast, more complex images that can be edited retrospectively can only be created with the help of a complicated structure with clearly separated surfaces. The SVG format is unable to produce photorealistic graphics due to the limited range of details (depths, shading, light effects, etc.).
Using vector graphics in SVG format on a website means that you are forced to take painstaking measure to create or reproduce complex graphics or refrain from using them altogether. It’s therefore advisable to only use vector graphics if you require the format’s strengths. If you want to display complex graphics, images, and photos, you should continue to use the well-known raster graphics formats.
Embedding SVG in HTML pages: how it works
SVG content is marked up in XML, meaning it bears the same structural and syntactical characteristics of any other XML document; essentially, the code is hierarchical, containing elements and attributes. An element is identified by a pair of tags, which always start with (<tag name>) and end with (</ tag name>). Attributes contain additional information about elements and are available as keyword pairs within a start or empty element tag (<tag name attribute name=’attribute value’>). It is also possible to insert instructions and comments. Each SVG XML document must contain exactly one element at the top level (<svg>), below which, any number of additional elements can be nested. The document type definition and XML declaration can also be used to define the type, version, and character encoding of the underlying document among other things.
It is no longer necessary to download additional plugins in order to embed this kind of graphic into a web project in SVG format. Instead, you can simply integrate the vector graphics directly into the HTML document, where you then have several options:
Embedding SVG with the image tag
<img src="example.svg" alt="embed SVG with the image tag">
Embedding an SVG file using the object tag as a multimedia object
<object data=’example.svg’ type=’image/svg+xml’>
<!—Fallback solution when SVG doesn’t load -->
<img src=‘alternativegraphic.png‘ alt=_‘Alternative PNG image‘>
Integrating SVG vector graphics as iFrames
<iframe src=’example.svg’ scrolling=’no’>
<p>SVG-Graphic – here in PNG format</p>
<img src=‘alternativegraphic.png‘ alt=‘Alternative PNG image‘>
Selecting an SVG graphic as a background image
It is possible to embed an SVG graphic as a background image using CSS in the same way as one might with a pixel graphic. In doing this, you can benefit from the SVG format’s lossless scalability; an SVG background automatically adjusts to the viewport (i.e. the available display area of the device in use) without a decrease in quality. If you want to use a vector graphic as a background image, simply create a corresponding div container like so:
<div style="background: url(example.svg);">
Displaying graphics directly in the HTML framework: the <svg> tag
In the following extract we provide an example of a small SVG variant for embedding the flag of Italy into an HTML framework:
<meta charset="UTF-8" />
<svg width="150" height="100" viewBox="0 0 3 2">
<rect width="1" height="2" x="0" fill="#008d46" />
<rect width="1" height="2" x="1" fill="#ffffff" />
<rect width="1" height="2" x="2" fill="#d2232c" />
Which appears in the browser like this:
Embedding SVGs – conclusion
For many years, the SVG format was considered an elegant and effective alternative to the pixel graphic formats such as PNG, JPEG, and GIF, which were more widely used in web development. Despite this, the format was associated with a considerable amount of extra work. This was primarily because some of the most popular browsers – most notably, Microsoft’s Internet Explorer – did not support the SVG format. However, in most cases today, an SVG file can be integrated as easily as any other image file. For many visual elements of a web project, vector graphics are an excellent choice; they can provide, among other things, responsive and barrier-free icons, buttons, logos, and fonts that can be easily adapted at any time.
The implementation of the SVG format can be mastered even by beginners in web development, thanks to the numerous variations of embedding and content management system functions. However, the design of the vector forms does require a good deal of prior knowledge. Not only are the right tools required, but you also need to have experience with vectors to get the most out of the lossless scaling graphics. But with some determination, it won’t be long before you can start to reap the benefits of the award-winning scripting language.
Want your website to stand out from the rest? Try out the IONOS Favicon Generator now for free!