I want it to look like the result of this code:
html {
font-size: 16px;
}
.ico {
display: inline-block;
}
.ico_size_s {
width: 1.3rem;
height: 1.3rem;
}
.ico_size_m {
width: 2rem;
height: 2rem;
}
.ico_first {
background-image: url();
background-color: yellow;
}
.ico_last {
background-image: url();
background-color: orange;
}
<i class="ico ico_first ico_size_s"></i>
<i class="ico ico_last ico_size_s"></i>
<hr />
<i class="ico ico_first ico_size_m"></i>
<i class="ico ico_last ico_size_m"></i>
There are two different data-uri for the two icons. One behaves as if it had the following properties:
background-repeat: no-repeat;
background-size: contain;
background-position: bottom;
How is it done?
If you do a Base64 decode of the first icon you get:
Whereas decoding the second one gives:
Notice that the second specifies a
width
andheight
of"16px"
for the SVG. That means it will always be drawn at that size no matter what. So when it is used as a background image it gets repeated if the container is larger than 16px in width or height.The first icon does not specify a
width
orheight
. So those attributes default to "100%". That means the icon gets scaled to fit the container.