关于圆角详解

基本语法:

  border-radius : none | <length>{1,4} [/ <length>{1,4} ]?

取值范围:

  <length>: 由浮点数字和单位标识符组成的长度值。不可为负值。

简单说明:

  border-radius 是一种缩写方法。如果“/”前后的值都存在,那么“/”前面的值设置其水平半径,“/”后面值设置其垂直半径。如果没有“/”,则水平和垂直半径相等。另 外其四个值是按照top-left、top-right、bottom-right、bottom-left的顺序来设置的其主要会有下面几种情形出现:

  1、只有一个值,那么 top-left、top-right、bottom-right、bottom-left 四个值相等。

  2、有两个值,那么 top-left 等于 bottom-right,并且取第一个值;top-right 等于 bottom-left,并且取第二个值

  3、有三个值,其中第一个值是设置top-left;而第二个值是 top-right 和 bottom-left 并且他们会相等,第三个值是设置 bottom-right。

  4、有四个值,其中第一个值是设置 top-left 而第二个值是 top-right 第三个值 bottom-right 第四个值是设置 bottom-left。

  前面,我们主要看了 border-radius 的缩写格式,其实 border-radius 和 border 属性一样,还可以把各个角单独拆分出来,也就是以下四种写法,这里我规纳一点,他们都是先Y轴在X轴,具体看下面:


1

2

3

4


border-top-left-radius: <length>  <length>   //左上角

border-top-right-radius: <length>  <length>  //右上角

border-bottom-right-radius:<length>  <length>  //右下角

border-bottom-left-radius:<length>  <length>   //左下角

  这里说一下,各角拆分出来取值方式:<length> <length> 中第一个值是圆角水平半径,第二个值是垂直半径,如果第二个值省略,那么其等于第一个值,这时这个角就是一个四分之一的圆角,如果任意一个值为0,那么这 个角就不是圆角。

  border-radius 只有在以下版本的浏览器:Firefox4.0+、Safari5.0+、Google Chrome 10.0+、Opera 10.5+、IE9+ 支持 border-radius 标准语法格式,对于老版的浏览器,border-radius 需要根据不同的浏览器内核添加不同的前缀,比说 Mozilla 内核需要加上“-moz”,而 Webkit 内核需要加上“-webkit”等,那么我为了能兼容各大内核的老版浏览器,我们看看 border-radius 在不同内核浏览器下的书写格式:

  1、Mozilla(Firefox, Flock等浏览器)


1

2

3

4


-moz-border-radius-topleft: //左上角

-moz-border-radius-topright: //右上角

-moz-border-radius-bottomright: //右下角

-moz-border-radius-bottomleft: //左下角

  等价于:


1


-moz-border-radius: //简写

  2、WebKit (Safari, Chrome等浏览器)


1

2

3

4


-webkit-border-top-left-radius:  //左上角

-webkit-border-top-right-radius:  //右上角

-webkit-border-bottom-right-radius:  //右下角

-webkit-border-bottom-left-radius:  // 左下角

等价于:


1


-webkit-border-radius:  //简写

  3、Opera浏览器:


1

2

3

4


border-top-left-radius: //左上角

border-top-right-radius: //右上角

border-bottom-right-radius: //右下角

border-bottom-left-radius: //左下角

等价于:


1


border-radius: //简写

  4、Trident (IE)

  IE9 以下版本不支持 border-radius,而且 IE9 没有私有格式,都是用 border-radius,其写法和 Opera 是一样的,这里就不在重复。

  为了不管是新版还是老版的各种内核浏览器都能支持 border-radius 属性,那么我们在具体应用中时需要把我们的 border-radius 格式改成:


1

2

3


-moz-border-radius: none | <length>{1,4} [/ <length>{1,4} ]?

-webkit-border-radius: none | <length>{1,4} [/ <length>{1,4} ]?

border-radius: none | <length>{1,4} [/ <length>{1,4} ]?

  其拆分开来的格式相应需要加上 -moz 和 -webkit,上面的代码其实就等价于下面的代码:


1

2

3

4

5

6

7

8

9

10

11

12


-moz-border-radius-topleft: <length> <length> //左上角

-moz-border-radius-topright: <length> <length> //右上角

-moz-border-radius-bottomright: <length> <length> //右下角

-moz-border-radius-bottomleft: <length> <length> //左下角

-webkit-border-top-left-radius:  <length> <length> //左上角

-webkit-border-top-right-radius:  <length> <length> //右上角

-webkit-border-bottom-right-radius: <length> <length> //右下角

-webkit-border-bottom-left-radius:  <length> <length> // 左下角

border-top-left-radius: <length> <length> //左上角

border-top-right-radius: <length> <length> //右上角

border-bottom-right-radius: <length> <length> //右下角

border-bottom-left-radius: <length> <length> //左下角

  另外需要特别注意的是,border-radius 一定要放置在 -moz-border-radius 和 -webkit-border-radius 后面,(特别声明:本文中所讲实例都只写了标准语法格式,如果你的版本不是上面所提到的几个版本,如要正常显示效果,请更新浏览器版本,或者在 border-radius 前面加上相应的内核前缀,在实际应用中最好加上各种版本内核浏览器前缀。)

  我们初步来看一个实例,HTML代码:


1


<div class="demo"></div>

  为了更好的看出效果,我们给这个demo添加一点样式:


1

2

3

4

5

6


.demo {

width: 150px;

height: 80px;

border: 2px solid #f36;

background: #ccc;

}

  注:如无特殊声明,本文实例所有基本代码格式如上所示,只在该元素上添加border-radius属性设置。


1

2

3


.demo {

border-radius: 10px 15px 20px 30px / 20px 30px 10px 15px;

}

  这种写法我们前面有提到过,“/”前是指圆角的水平半径,而“/”后是指圆角的垂直半径,他们两都遵循TRBL(上右下左)的顺序原则。为了能让大家更清楚理解,我们把上面代码换成如下:


1

2

3

4

5

6


.demo {

border-top-left-radius: 10px 20px;

border-top-right-radius: 15px 30px;

border-bottom-right-radius: 20px 10px;

border-bottom-left-radius: 30px 15px;

}

  不仿看看他们的效果:

  

  三、支持的浏览器:

  

  上面我们介绍了border-radius的基本用法,以及在各大浏览器下的格式等,下面我们通过实例来介绍其具体的用法:

  一:border-radius只有一个取值时,四个角具有相同的圆角设置,其效果是一致的:


1

2

3


.demo {

border-radius: 10px;

}

其等价于:


1

2

3

4

5

6


.demo{

border-top-left-radius: 10px;

border-top-right-radius: 10px;

border-bottom-right-radius: 10px;

border-bottom-left-radius: 10px;

}

  效果:

  

  二:border-radius设置两个值,此时top-left等于bottom-right并且他们取第一个值;top-right等于bottom-left并且他们取第二个值,也就是说元素 左上角和右下角相同,右上角和左下角相同


1

2

3


.demo {

border-radius: 10px 20px;

}

  等价于:


1

2

3

4

5

6


.demo {

border-top-left-radius: 10px;

border-bottom-right-radius: 10px;

border-top-right-radius: 20px;

border-bottom-left-radius: 20px;

}

  效果:

  

  三:border-radius设置三个值,此时top-left取第一个值,top-right等于bottom-left并且他们取第二个值,bottom-right取第三个值:


1

2

3


.demo {

border-radius: 10px 20px 30px;

}

  等价于:


1

2

3

4

5

6


.demo {

border-top-left-radius: 10px;

border-top-right-radius: 20px;

border-bottom-left-radius: 20px;

border-bottom-right-radius: 30px;

}

  效果:

  

  四:border-radius设置四个值,此时top-left取第一个值,top-right取第二个值,bottom-right取第三个值.bottom-left取第四个值:


1

2

3


.demo {

border-radius:10px 20px 30px 40px;

}

  等价于:


1

2

3

4

5

6


.demo {

border-top-left-radius: 10px;

border-top-right-radius: 20px;

border-bottom-right-radius: 30px;

border-bottom-left-radius: 40px;

}

  效果:

  

  从上面四个实例中我们可以看出border-radius和border取值非常相似,我们border遵循TRBL原则(从上边右边下边左边 分别对应1、2,3,4四个值),只不过border-radius换成了左上角(top-left)对就值1,右上角(top-right)对应值2, 右下角(bottom-right)对应值3,左下角(bottom-left)对应值4.

  上面四个实例都是水平和垂直半径相等情况下border-radius的应用,下面我们来看几个水平和垂直半径值不一样的实例:

  一、border-radius: 水平 / 垂直:只设置一个水平和一个垂直半径时,那么水平半径分别指定了元素个四个角的水平半径值,同样垂直半径指定了元素的垂直半径值,此时四个角具有相同的效果,因为他们具有相同的值:


1

2

3


.demo {

border-radius: 10px / 20px;

}

  等价于:


1

2

3

4

5

6


.demo {

border-top-left-radius: 10px 20px;

border-top-right-radius: 10px 20px;

border-bottom-right-radius: 10px 20px;

border-bottom-left-radius: 10px 20px;

} 

  效果:

  

  此时我们每个角不在是四分之一圆了,前面我们也说过,只有水平和垂直半径值相同时,他们才具有四分之一圆特性,这样一来,我们可以改变不同的半径值,制作一些特殊的图形效果,感兴趣的朋友可以自己在本地尝试一下各种不同的设置方式。

  二、border-radius: 水平1 水平2 / 垂直1  垂直2:设置了两个水平值和两个垂直值,此时我们top-left和bottom-right具有相同的水平和垂直半径,也就是其中的水平1和垂直1;而 top-right和bottom-left也具有相同的水平和垂直半径值,也就是水平2和垂直2,我们他拆分出来就是:


1

2

3

4


border-top-left-radius: 水平1  垂直1;

border-bottom-right-radius: 水平1  垂直1;

border-top-right-radius: 水平2  垂直2;

border-bottom-left-radius: 水平2  垂直2;

  具体我们来看下面的实例:


1

2

3


.demo {

border-radius: 10px 20px / 20px 10px;

}<em id="__mceDel" style="font-family: verdana, Arial, Helvetica, sans-serif; font-size: 14px; line-height: 1.5;"> </em>

  等价于:


1

2

3

4

5

6


.demo {

border-top-left-radius: 10px 20px;

border-bottom-right-radius: 10px 20px;

border-top-right-radius: 20px 10px;

border-bottom-left-radius: 20px 10px;

}

  效果:

  

  上面两种都是相互对应的取值,我们来看一个实例,水平有三个取值,而 垂直只有两个取值:


1

2

3


.demo {

border-radius: 10px 20px 30px / 50px 60px;

}

  等价于:


1

2

3

4

5

6


.demo {

border-top-left-radius: 10px 50px;

border-top-right-radius: 20px 60px;

border-bottom-left-radius: 20px 60px;

border-bottom-right-radius: 30px 50px;

}

  效果:

  

  我们从上面等价代码中可以知道,不管他们怎么取值,“/”前后各自按TRBL顺序取值。

  上面几种都是我们常见的一些应用,那下面我们来看几种特殊点的应用:

  一、对于border-radius还有一个内半径和外半径的区别,它主要是元素 边框值较大时,效果就很明显,当我们border-radius半径值小于或等于border的厚度时,我们边框内部就不具有圆角效果,例如下面的实例:


1

2

3

4


.border-big {

border: 15px solid green;

border-radius: 15px;

}

  效果:

  

  我们接着上面这个例子,把 border-radius半径值改成比边框值大一点:


1

2

3

4


.border-small {

border: 15px solid green;

border-radius: 25px;

}

  效果:

  

  为何当border-radius的半径小于元素边框的厚度时,内部没有圆角效果?我在这里说一下,因为我们的border-radius的内 径值是等于外径值减去边框厚度值,当他们的值为负时,内径默认为0,最前面讲border-radius取值时就说过其值不能为负值。同时也说明 border-radius的内外曲线的圆心并不一定是一致的。只有当边框厚度为0时,我们内外曲线的圆心才会在同一位置。

  二、如果角的两个相邻边有不同的宽度,那么这个角将会从宽的边平滑过度到窄的边。其中一条边甚至可以是0。相邻转角是由大向小转。


1

2

3

4


.demo {

border-width: 10px 5px 20px 3px;

border-radius: 30px;

}

  效果:

  

  三、相邻两条边颜色和线条样式不同时,那么两条相邻边颜色和样式转变的中心点是在一个和两边宽度成正比的角上。比如,两条边宽度相同,这个点就 是一个45°的角上,如果一条边是另外一条边的两倍,那么这个点就在一个30°的角上。界定这个转变的线就是连接在内外曲线上的两个点的直线。我们来看一 个四边颜色不一样,宽度不一样的实例:


1

2

3

4

5


.demo {

border-color: red green blue orange;

border-width: 15px 30px 30px 80px;

border-radius: 50px;

}

  效果:

  

  上面这几种是比较特殊点的用法,如果大家还想通过border-radius制作更多不同形状,或者更多的应用,可以点击这里

  border-radius能应用在各种元素中,但在img和table应用时会有点差别的,首先先来看图片上应用border-radius 时的情况。在img上应用border-radius到目前只有Firefox4.0+浏览器才正常,而在其他浏览器都不能对图片进行剪切,我们先来看一 个实例:


1

2

3

4


img {

border: 5px solid green;

border-radius: 15px;

}

  我们来看其在各浏览器下的效果:

  

  左图是在Safari5.0、Google Chrome 10.0、Opera11.1下的效果,我们可以看得出,图片根本就没有圆角效果,右图是在Firefox4.0下的效果,低于这个版本的和左图一样效 果,如果需要达成一致效果,大家就必须放弃border-radius而采用CSS2制作圆角的老办法。另外table的样式属性border- collapse是collapse时,border-radius不能正常显示,只有border-collapse: separate;时才能正常显示。


1

2

3

4

5

6


table {

border-collapse: collapse;

border: 2px solid red;

background: green;

border-radius: 15px;

}

  效果:

  

时间: 2024-10-26 16:50:59

关于圆角详解的相关文章

css3圆角详解

css3(border-radius)边框圆角详解 传统的圆角生成方案,必须使用多张图片作为背景图案.CSS3的出现,使得我们再也不必浪费时间去制作这些图片了,只需要border-radius属性,支持浏览器IE 9.Opera 10.5.Safari 5.Chrome 4和Firefox 4 一.border-radius属性 CSS3圆角只需设置一个属性:border-radius(含义是"边框半径").你为这个属性提供一个值,就能同时设置四个圆角的半径.所有合法的CSS度量值都可

css3(border-radius)边框圆角详解

传统的圆角生成方案,必须使用多张图片作为背景图案.CSS3的出现,使得我们再也不必浪费时间去制作这些图片了,只需要border-radius属性,支持浏览器IE 9.Opera 10.5.Safari 5.Chrome 4和Firefox 4 一.border-radius属性 CSS3圆角只需设置一个属性:border-radius(含义是"边框半径").你为这个属性提供一个值,就能同时设置四个圆角的半径.所有合法的CSS度量值都可以使用:em.px.百分比等等. 比如,下面是一个d

CSS3圆角详解(border-radius)

1.CSS3圆角的优点 传统的圆角生成方案,必须使用多张图片作为背景图案.CSS3的出现,使得我们再也不必浪费时间去制作这些图片了,而且还有其他多个优点: 减少维护的工作量.图片文件的生成.更新.编写网页代码,这些工作都不再需要了. 提高网页性能.由于不必再发出多余的HTTP请求,网页的载入速度将变快. 增加视觉可靠性.某些情况下(网络拥堵.服务器出错.网速过慢等等),背景图片会下载失败,导致视觉效果不佳.CSS3就不会发生这种情况. 2.border-radius属性 CSS3圆角只需设置一个

css3:border-radius圆角边框详解 (变圆 图片)

转:http://www.kuqin.com/shuoit/20141014/342620.html border-radius:50% 今天来聊聊这个border-radius属性,radius的英文意思是弧度的意思,而国人更喜欢称之为圆角,因为它可以使得我们的边框有棱有角.当年前辈们都是用图片君搞定圆角的年代或用一条条边框构造的年代已经一去不复返,而移动互联网的高速发展为border-radius属性的飞速发展,so今天就来聊聊圆角边框.虽然英文翻译过来叫做半径弧度,但是为了能让大家更加熟悉

Android基础入门教程——8.3.4 Paint API之—— Xfermode与PorterDuff详解(一)

Android基础入门教程--8.3.4 Paint API之-- Xfermode与PorterDuff详解(一) 标签(空格分隔): Android基础入门教程 本节引言: 不知道标题这两个玩意你熟不熟悉啦,如果自己实现过圆角或者圆形图片,相信对这两个名词 并不模式,一时半伙没想起来?没关系,下面这个图你可曾见过? PS:网上都说在:\samples\android-XX\legacy\ApiDemos\src\com\example\android\apis\graphics 下能找到这个

UITextField详解

UITextField详解 一.基本属性 1.创建文本输入框 UITextField*textField=[[UITextField alloc]initWithFrame:CGRectMake(10, 10, 200, 20)]; 2.设置边框样式 textField.borderStyle = UITextBorderStyleRoundedRect;//圆角 可选属性: UITextBorderStyleNone,无边框 UITextBorderStyleLine,有边框 UITextBo

Shape 各种属性详解

本文来自:http://blog.csdn.net/brokge/article/details/9713041 简介: 作用:XML中定义的几何形状 位置:res/drawable/文件的名称.xml 使用的方法: Java代码中:R.drawable.文件的名称 XML中:Android:background="@drawable/文件的名称" 属性: <shape>形状 Android:shape=["rectangle" | "oval

安卓项目五子棋代码详解(五)

这一期给大家带来我自己添加的功能,最近还搞了个播放背景音乐和下棋音效,与这个一起讲了 开笔之前,忽然响起还有一个保存游戏没讲,真是失误. 保存游戏呢,就是将当前棋子的位置都保存下来,我们可以设想一个情景,玩家玩着游戏的时候,忽然一个电话过来,就会跳转到打电话的界面,或者一条QQ消息要处理,玩家跳转到了QQ的界面处理消息,待他处理完之后,就会返回游戏,如果我们没有设置保存游戏的这个方法的话,那么玩家再次进入的时候就是跟开始的一样,这样的体验非常糟糕,所以保存游戏这个方法是必须要有的. 首先在Pan

iOS动画详解(学习动画看这一篇就够了)

iOS动画详解(学习动画看这一篇就够了) 一.基础知识 CAAnimation.png 二.CABasicAnimation 1. 动画的属性和解释 2.属性值的解释 repeatCount : 如果在swift中需要一直不断重复:Float.infinity,OC:HUGE_VALF timingFunction: timingFunction.png kCAMediaTimingFunctionLinear--在整个动画时间内动画都是以一个相同的速度来改变.也就是匀速运动.一个线性的计时函数