So I have HTML markup that looks like this:
<a href="#" data-icon="...">Some link</a>
Then I want to use that data-icon
in my CSS to display as the base 64 background image. Something like:
a:before {
content: "";
width: 16px;
height: 16px;
padding-left: 16px;
background: url(attr(data-icon)); // this doesn't work
}
Is there any way to do this?
Try:
content: attr(data-icon);
Codepen
JsFiddle
This will only work for text based data
attributes though and not images.
You can apply a normal background, but only content
allows attr
.
(but not how you may think)
a{
background-image:url(https://encrypted-tbn2.gstatic.com/images?q=tbn:ANd9GcRrlZZQ3MwNcconkIeLX3_nS_IV81gJ8rincQsipqXGsiBkPmCX);
background-repeat:no-repeat;
background-position:1000px 1000px;
}
a:before {
content: '';
width: 16px;
height: 16px;
padding-left: 16px;
background-image: inherit;
background-position:0px 0px;
}
Unfortunately what you are attempting to do will not work, attr
is only applicable to the content
property.
The only possible alternative would be to give the parent a background image, then set background-image
on the pseudo element to inherit
. If you set the parent elements background-position
outside its boundaries then the psuedo elements to zero, it will give the same effect of no image on the parent, but an image on the psuedo.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With