Reputation: 3424
As the title says - how do I wrap text around a pseudoelement? See example below:
.area {
position: relative;
}
.area:before {
content: '';
display: block;
position: absolute;
left: 0;
width: 80px;
height: 80px;
background-image: url('https://image.flaticon.com/sprites/new_packs/181501-interface.png');
background-position: 7px -278px;
}
<div class="area">
<p>"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."</p>
</div>
I did some preliminary research and found this answer:
Getting H1 text to wrap beside a ::before pseudo element
Adding a float: left;
does not work:
.area {
position: relative;
}
.area:before {
content: '';
display: block;
position: absolute;
left: 0;
/*SO answer #1*/
float: left;
width: 80px;
height: 80px;
background-image: url('https://image.flaticon.com/sprites/new_packs/181501-interface.png');
background-position: 7px -278px;
}
<div class="area">
<p>"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."</p>
</div>
Is this even possible? If so - how best do I go about accomplishing it?
Upvotes: 1
Views: 63
Reputation: 7171
remove position: absolute;
from css
.area {
position: relative;
}
.area:before {
content: '';
display: block;
//position: absolute;
left: 0;
/*SO answer #1*/
float: left;
width: 80px;
height: 80px;
background-image: url('https://image.flaticon.com/sprites/new_packs/181501-interface.png');
background-position: 7px -278px;
}
<div class="area">
<p>"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure
dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."</p>
</div>
Upvotes: 2
Reputation: 4596
Almost there, just remove the position: absolute
from your second attempt.
Upvotes: 3