CSS3圆角
注意:由于CSS3中的部分内容尚未完全定稿,所以本文的部分可能会随时更新。
CSS Level3中正式开始支持圆角属性,官方给出的文档在这里。本篇文章将会介绍CSS3中border-radius
的相关知识和用法。
在CSS3支持圆角之前,我们要想实现圆角效果,得用多张图片进行定位,经过一系列精细的调试才能得到想要的效果。这种方法也是无奈之举,而且很麻烦,同时它具有几个不可避免的弊端,
- 增加了页面文件及静态资源的维护成本
- 增加了额外的网络带宽消耗(因为需要加载更多的图片)
现在直接对元素设置border-radius
属性即可达到圆角的效果。其语法如下,
border-radius: <length>{1-4} | % / <length>{1-4} | %;
即,可以设置
- 1~4长度值
- 一个百分比
- 可以设置两组值,使用
/
连接
比如,我有如下的代码,
<style>
#border-radius {
width: 200px;
height: 200px;
border: 1px solid;
background-color: #0a0;
border-radius: 20px;
}
</style>
<div id="border-radius"></div>
其效果如下,
上述的代码中,我只给border-radius
属性设置了一个值。其实border-radius
跟border
属性时很相似的,它是一个复合属性,可分为左上、右上、左下、右下共四个可赋值项。前面说过,border-radius
可以赋值1~4个值,
- 设置1个值时,四个方向都使用同一个值
- 设置2个值时,左上和右下使用第一个值,右上和左下使用第二个值
- 设置3个值时,左上使用第一个值,右上和左下使用第二个值,右下使用第三个值
- 设置4个值时,分别对应左上、右上、左下、右下的顺序进行赋值
除了直接设置1~4个长度单位之外,我们还可以设置百分比(%),比如
#border-radius {
width: 200px;
height: 200px;
background-color: #0a0;
border: 1px solid;
border-radius: 10% 20% 50%;
}
其效果如下,
其实border-radius
属性意为边框半径,它分为水平半径和垂直半径,如下图
我们在设置border-radius
时其实还可以使用形如下面示例的赋值方式,
#border-radius {
width: 200px;
height: 200px;
background-color: #0a0;
border: 1px solid;
border-radius: 10px 50px 15px 50px/5px 20px 10px 20px;
}
其效果如下,
我们可以给水平或者垂直半径分别进行赋值。所以,我们可以给不同方向设置圆角,同时还可以分别设置其水平或者垂直半径来达到不同曲率的圆角。
当我们使用/
设置圆角时,第一组属性为水平半径的赋值,第二组值为垂直半径赋值。且赋值的方向规律与前述一致。
除此之外,CSS3还支持对元素的某个角进行赋值,
border-top-left-radius
,左上角border-top-right-radius
,右上角border-bottom-right-radius
,右下角border-bottom-left-radius
,左下角
这四个属性都可以设置1~2个值,如下
.test {
border-top-left-radius: 10px 20px;
border-top-right-radius: 15px;
border-bottom-right-radius: 0;
border-bottom-left-radius: 0;
}
- 若设置一个值,则表示水平半径和垂直半径相同
- 若设置两个值,则表示分别按顺序设置水平、垂直半径
兼容性:虽然目前各大主流现代浏览器都支持border-radius
属性,不过在具体的实现细节上可能会有所差别,针对不同的浏览器需要添加各自的浏览器兼容前缀。
更多建议: