Problem:
Creating a slanted div using borders is not feasible when the div is placed over an image. How can a slanted edge be created using CSS that is also responsive?
Solution:
A skewed pseudo element can be used to create the slanted background. This approach keeps the text unaffected by the transform operation. Here's how to achieve it:
Example Code:
div { position: relative; display: inline-block; padding: 1em 5em 1em 1em; overflow: hidden; color: #fff; } div:after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #000; -webkit-transform-origin: 100% 0; -ms-transform-origin: 100% 0; transform-origin: 100% 0; -webkit-transform: skew(-45deg); -ms-transform: skew(-45deg); transform: skew(-45deg); z-index: -1; } body { background: url("https://farm3.staticflickr.com/2878/10944255073_973d2cd25c.jpg"); background-size: cover; }
HTML:
<div>slanted div text</div> <div> slanted div text<br /> on several lines<br /> an other line </div> <div>wider slanted div text with more text inside</div>
The above is the detailed content of How to Create a Slanted Div Without Using Borders in CSS?. For more information, please follow other related articles on the PHP Chinese website!