"Se um trabalhador quiser fazer bem o seu trabalho, ele deve primeiro afiar suas ferramentas." - Confúcio, "Os Analectos de Confúcio. Lu Linggong"
Primeira página > Programação > Como posso criar um raio de borda inserido usando gradientes CSS3?

Como posso criar um raio de borda inserido usando gradientes CSS3?

Publicado em 2025-01-06
Navegar:480

How Can I Create an Inset Border-Radius Using CSS3 Gradients?

Inset Border-Radius usando gradientes CSS3

Conseguir um raio de borda inserido sem imagens é possível através do uso de gradientes CSS3. Essa abordagem envolve a camada de vários gradientes radiais transparentes para criar a ilusão de uma borda curvada para dentro ao redor de um elemento.

O código CSS a seguir emprega a solução de Lea Verou para criar um raio de borda inserido usando gradientes:

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;
}

Neste código, vários gradientes radiais transparentes são posicionados em pontos específicos ao redor do elemento para criar a ilusão de uma curva interna. O resultado é um conjunto de gradientes transparentes com curvas, produzindo um efeito de raio de borda inserido.

É importante observar que esta solução requer suporte para RGBA e gradientes, que podem não ser suportados por todos os navegadores mais antigos e requer aprimoramento progressivo ou substituto baseado em imagem para navegadores mais antigos que não suportam gradientes.

Tutorial mais recente Mais>

Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.

Copyright© 2022 湘ICP备2022001581号-3