”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何使用 CSS3 渐变创建内嵌边框半径?

如何使用 CSS3 渐变创建内嵌边框半径?

发布于2025-01-06
浏览:598

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

使用 CSS3 渐变插入边框半径

通过使用 CSS3 渐变可以实现没有图像的插入边框半径。这种方法涉及分层几个透明的径向渐变,以创建元素周围向内弯曲的边框的错觉。

以下 CSS 代码采用 Lea Verou 的解决方案,使用渐变创建内嵌边框半径:

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

在此代码中,多个透明径向渐变位于元素周围的特定点,以创建向内曲线的错觉。结果是一组带有曲线的透明渐变,产生内嵌边框半径效果。

需要注意的是,该解决方案需要支持 RGBA 和渐变,这可能不是所有旧版浏览器都支持,并且需要针对不支持渐变的旧浏览器的渐进增强或基于图像的后备。

最新教程 更多>

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3