SVG
<svg version="1.1"
width="300" height="200"
xmlns="http://www.w3.org/2000/svg">
<rect width="100%" height="100%" fill="red"/>
<circle cx="150" cy="100" r="80" fill="green"/>
<text x="150" y="125" font-size="60" text-anchor="middle" fill="white">SVG</text>
</svg>
CSS
<a href="/" class="logo"> Kiwi Corp </a>
.logo {
display: block;
text-indent: -9999px;
width: 100px;
height: 82px;
background: url(kiwi.svg);
background-size: 100px 82px;
}
or
.main-header {
background: url(logo.svg) no-repeat top left;
background-size: contain;
}
.no-svg .main-header {
background-image: url(logo.png);
}
or
.illustration {
background-image: url("image.svg");
}
And just like raster graphics, you can base64 encode them right into the stylesheet to help reduce HTTP requests:
.illustration {
background-image: url("data:image/svg+xml;base64,[data]");
}
To aid readability, you may even attempt such audacity as this:
.illustration {
background-image: url("data:image/svg+xml;charset=utf-8,<svg></svg>");
}
html
svg element
<svg
baseProfile="full"
height="200"
version="1.1"
width="300"
xmlns="http://www.w3.org/2000/svg"
>
<rect fill="black" height="100%" width="100%"/>
<circle cx="150" cy="100" fill="blue" r="90"/>
</svg>
image element
<img src="image.svg" onerror="this.onerror=null; this.src='image.png'"/>
body element
body {
background: url(fallback.png);
background-image: url(image.svg), none;
}
inline
<body>
<!-- paste in SVG code, image shows up! -->
</body>
iframe element
<iframe height="500" sandbox src="triangle.svg" width="500">
<img alt="Triangle with three unequal sides" src="triangle.png"/>
</iframe>
object element
<object type="image/svg+xml" data="image.svg">
<img src="fallback.png"/>
</object>
This is the oldest method we have. And of course, data URIs are possible here too:
<object type="image/svg+xml" data="data:image/svg+xml;base64,[data]">
<img src="fallback.png"/>
</object>
If the browser doesn’t recognise the object element’s MIME type, it won’t download the SVG file, but the “fallback”
image inside is always downloaded.
Again, we’re not doing things quite right.
There
is a better solution and those crafty devils at ClearLeft are sporting it in their logo markup.
The answer?
Simply use CSS to apply the fallback image:
<object id="logo" type="image/svg+xml" data="logo.svg">
<div>logo description</div>
</object>
#logo div {
width: 300px;
height: 50px;
background-image: url("logo.png");
}
The object element effectively replaces its default content with the SVG data.
Only if the browser doesn’t support SVG, does the element inside get styled.
This, to my knowledge, is the best way to
use SVG without any overhead.
Data URI
The data URI format is pretty simple and is spelled out in RFC 2397 (which actually is short enough that you can read
it all). The basic format is
as follows:
data:[<mime type>][;charset=<charset>][;base64],<encoded data>
In this format,
data:
is the protocol of the URI, indicating that this is a data URI.
The second part, theMIME type
, indicates the type of data being represented.
For PNG images, for
example, this would beimage/png
.
When not specified, theMIME
type defaults totext/plain
.
The character set can, most often, safely be omitted and isn’t used at all for images.
The
next section indicates the encoding used.
Contrary to popular belief, you do not have to usebase 64 encoding
.
If the content isn’t base 64 encoded, then the data is encoded using standard
URL-encoding (URL-safeASCII
characters represented as themselves, all others represented as a hex encoding in the
format%xx
).
The encoded data may contain white space, which is not
considered significant.
Formats
<!-- base64 -->
...
<!-- UTF-8, not encoded -->
data:image/svg+xml;charset=UTF-8,<svg ...> ... </svg>
<!-- UTF-8, optimized encoding for compatibility -->
data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://...'
example :
data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M224%20387.814V512L32 320l192-192v126.912C447.375 260.152 437.794 103.016 380.93 0 521.287 151.707 491.48 394.785 224 387.814z'/%3E%3C/svg%3E
<!-- Fully URL encoded ASCII -->
data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A//...
example :
data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20512%20512%22%3E%3Cpath%20d%3D%22M224%20387.814V512L32%20320l192-192v126.912C447.375%20260.152%20437.794%20103.016%20380.93%200%20521.287%20151.707%20491.48%20394.785%20224%20387.814z%22%2F%3E%3C%2Fsvg%3E
css
.logo {
background: url("data:image/svg+xml;base64,[data]");
}
li {
background: url() no-repeat left center;
padding: 5px 0 5px 25px;
}
or
html {
background-image: url(),
url(/TBEX/resource/src/815-teams-north-gate-path.jpg);
background-size: cover;
background-repeat: no-repeat;
background-position: center;
background-attachment: fixed;
height: 100%;
}
What I have used to get data uri to work with using as background css
first use at TPlus
element { background: url(); background-size: cover; background-repeat: no-repeat; background-position: center; height: 100%; width: 90%; }
Option 2
element { background: url() no-repeat; display: 100% auto; background-size: 100%; background-position: center; width: 100%; height: 100%; margin:0 auto; }
Option 3
element { background: url() no-repeat; background-position: top; background-size: contain; width: auto; height: auto; margin: auto; }
Simple Option
element { background: url() no-repeat; background-position: center; background-size: 100% auto; }
Preload Image with CSS and HTML
.masthead {
height: 100vh;
background-image: url("[masthead.jpg|<data URI>]");
background-size: cover;
}
<link rel="preload" href="masthead.jpg" as="image"/>
<title>Preloaded Image</title>
<link rel="stylesheet" href="image.css"/>
image
<img src="data:image/svg+xml;base64,[data]"/>
<img
alt="star"
height="16"
src=""
width="16"
/>
iframe
<iframe
width="600"
height="200"
src="data:text/html;charset=utf-8;base64,PCFET0...C9odG1sPg=="
></iframe>
object
<object type="image/svg+xml" data="data:image/svg+xml;base64,[data]">
fallback
</object>