"If a worker wants to do his job well, he must first sharpen his tools." - Confucius, "The Analects of Confucius. Lu Linggong"
Front page > Programming > How Can I Create Inset Border-Radius Using Only CSS3?

How Can I Create Inset Border-Radius Using Only CSS3?

Published on 2024-12-21
Browse:615

How Can I Create Inset Border-Radius Using Only CSS3?

Inset Border-Radius with CSS3

In CSS3, achieving inset border-radius, where the corners are curved inward rather than outward, can be challenging without using images. However, there's a clever solution that utilizes CSS3 gradients.

Lea Verou's ingenious approach involves creating a series of transparent gradients with curves, creating the illusion of inset border-radius. By positioning these gradients precisely, you can achieve the desired rounded corners effect.

Her CSS code, as seen below, defines a custom class for an element with the desired inset border-radius:

div.round {
    background:
        -moz-radial-gradient(0 100%, circle, rgba(204,0,0,0) 14px, #c00 15px),
        -moz-radial-gradient(100% 100%, circle, rgba(204,0,0,0) 14px, #c00 15px),
        -moz-radial-gradient(100% 0, circle, rgba(204,0,0,0) 14px, #c00 15px),
        -moz-radial-gradient(0 0, circle, rgba(204,0,0,0) 14px, #c00 15px);
    background:
            -o-radial-gradient(0 100%, circle, rgba(204,0,0,0) 14px, #c00 15px),
            -o-radial-gradient(100% 100%, circle, rgba(204,0,0,0) 14px, #c00 15px),
            -o-radial-gradient(100% 0, circle, rgba(204,0,0,0) 14px, #c00 15px),
            -o-radial-gradient(0 0, circle, rgba(204,0,0,0) 14px, #c00 15px);
    background:
            -webkit-radial-gradient(0 100%, circle, rgba(204,0,0,0) 14px, #c00 15px),
            -webkit-radial-gradient(100% 100%, circle, rgba(204,0,0,0) 14px, #c00 15px),
            -webkit-radial-gradient(100% 0, circle, rgba(204,0,0,0) 14px, #c00 15px),
            -webkit-radial-gradient(0 0, circle, rgba(204,0,0,0) 14px, #c00 15px);
    background-position: bottom left, bottom right, top right, top left;
        -moz-background-size: 50% 50%;
        -webkit-background-size: 50% 50%;
    background-size: 50% 50%;
    background-repeat: no-repeat;
}

Applying this class to an element will result in an element with inset border-radius. It's important to note that this technique relies on support for rgba and gradients, making it a progressive enhancement strategy. For older browsers or browsers that don't support gradients, an image-based fallback is recommended for providing support.

Latest tutorial More>

Disclaimer: All resources provided are partly from the Internet. If there is any infringement of your copyright or other rights and interests, please explain the detailed reasons and provide proof of copyright or rights and interests and then send it to the email: [email protected] We will handle it for you as soon as possible.

Copyright© 2022 湘ICP备2022001581号-3