最安全的写法是单值 border-radius: 10px,四角等半径得标准圆角矩形;斜杠写法如 10px/20px 会触发椭圆模式;四值需严格按左上、右上、右下、左下顺序;超尺寸时浏览器自动限制为宽高一半;表格中需对单元格设圆角并配合 overflow: hidden 裁剪。
直接写 border-radius: 10px 是最安全的起点,四个角等半径,浏览器会生成标准圆角矩形。但一旦你用斜杠写成 border-radius: 10px / 20px,就进入了椭圆模式:斜杠前是水平方向半径,斜杠后是垂直方向半径。很多 UI 设计稿只标一个数值,结果开发者误用斜杠写法,导致
按钮上下边弧度被拉扁。
border-radius: 8px → 四角一致border-radius: 8px / 4px → 水平 8px、垂直 4px,适合胶囊形标签border-radius: 4px 8px 4px 0 → 顺时针:左上、右上、右下、左下很多人想只圆两个对角,却错误地写成 border-radius: 8px 0 0 8px(这是左上+左下),顺序错了。CSS 的四值顺序固定为「左上、右上、右下、左下」,所以要圆左上和右下,必须显式把中间两个设为 0:
button {
border-radius: 8px 0 8px 0;
}
注意:不能省略中间值,border-radius: 8px 0 等价于 8px 0 8px 0,看似一样,但语义是「左上+右上」,右下和左下会自动继承右上和左上——这反而会圆错角。务必写满四值或用 border-top-left-radius 和 border-bottom-right-radius 单独控制。
当 border-radius 值大于元素宽高一半时,浏览器会自动限制为最大可接受值,不会报错,但视觉上可能意外变“全圆”。比如一个 width: 20px; height: 20px 的元素,设 border-radius: 50px,实际渲染就是 10px(20/2),最终是个正圆。但若宽高不等,如 width: 40px; height: 20px,设 border-radius: 20px,水平方向刚好撑满,垂直方向只能取 10px,结果是横向拉伸的椭圆——不是 bug,是规范行为。
width === height,再设 border-radius: 50%
50% 基于盒模型的宽高分别计算,不是统一缩放表格加了 注意:IE 不支持 border-collapse: collapse 后,border-radius 在 上基本无效,因为边框被合并压缩,圆角失去作用点。真正有效的做法是:给
或 单独设圆角,并配合 overflow: hidden 在父 上裁剪溢出:
table {
border-collapse: collapse;
overflow: hidden;
border-radius: 8px;
}
th:first-child,
td:first-child {
border-top-left-radius: 8px;
border-bottom-left-radius: 8px;
}
th:last-child,
td:last-child {
border-top-right-radius: 8px;
border-bottom-right-radius: 8px;
}
border-radius 作用于 ,哪怕加了
overflow: hidden,必须降级为包裹一层 并对其设圆角。