<style type="text/css"> .b1,.b2,.b3,.b4,.b1b,.b2b,.b3b,.b4b,.b{}{display:block;overflow:hidden;} .b1,.b2,.b3,.b1b,.b2b,.b3b{}{height:1px;} .b2,.b3,.b4,.b2b,.b3b,.b4b,.b{}{border-left:1px solid #999;border-right:1px solid #999;} .b1,.b1b{}{margin:0 5px;background:#999;} .b2,.b2b{}{margin:0 3px;border-width:2px;} .b3,.b3b{}{margin:0 2px;} .b4,.b4b{}{height:2px;margin:0 1px;} .d1{}{background:#F7F8F9;} .k {}{height:300px;} </style> </head> <body> <div> <b class="b1"></b><b class="b2 d1"></b><b class="b3 d1"></b><b class="b4 d1"></b> <div class="b d1 k"> <font style="font-size:26px;color:red; margin:0px 10px;">简洁型css圆角矩形</font> </div> <b class="b4b d1"></b><b class="b3b d1"></b><b class="b2b d1"></b><b class="b1b"></b> </div> 3D圆角矩形: <style type="text/css"> .raised{}{background:transparent;width:40%;} .raised h1,.raised p{}{margin:0 10px;} .raised h1{}{font-size:2em;color:#fff;} .raised p{}{padding-bottom:0.5em;} .raised .b1,.raised .b2,.raised .b3,.raised .b4,.raised .b1b,.raised .b2b,.raised .b3b,.raised .b4b{}{display:block;overflow:hidden;font-size:1px;} .raised .b1,.raised .b2,.raised .b3,.raised .b1b,.raised .b2b,.raised .b3b{}{height:1px;} .raised .b2{}{background:#ccc;border-left:1px solid #fff;border-right:1px solid #eee;} .raised .b3{}{background:#ccc;border-left:1px solid #fff;border-right:1px solid #ddd;} .raised .b4{}{background:#ccc;border-left:1px solid #fff;border-right:1px solid #aaa;} .raised .b4b{}{background:#ccc;border-left:1px solid #eee;border-right:1px solid #999;} .raised .b3b{}{background:#ccc;border-left:1px solid #ddd;border-right:1px solid #999;} .raised .b2b{}{background:#ccc;border-left:1px solid #aaa;border-right:1px solid #999;} .raised .b1{}{margin:0 5px;background:#fff;} .raised .b2, .raised .b2b{}{margin:0 3px;border-width:0 2px;} .raised .b3, .raised .b3b{}{margin:0 2px;} .raised .b4, .raised .b4b{}{height:2px; margin:0 1px;} .raised .b1b{}{margin:0 5px; background:#999;} .raised .boxcontent{}{display:block;background:#ccc;border-left:1px solid #fff;border-right:1px solid #999;} </style> </head> <body> <div class="raised"> <b class="b1"></b><b class="b2"></b><b class="b3"></b><b class="b4"></b> <div class="boxcontent"> <h1>3D圆角矩形</h1> </div> <b class="b4b"></b><b class="b3b"></b><b class="b2b"></b><b class="b1b"></b> </div> CSS3实现圆角 <div style="background-color: blue; height: 50px; width: 100px; border-width: 5px; border-style: solid; border-radius: 15px">Firefox 和 Safari 实现圆角</div> 1.CSS3是样式表(style sheet)语言的最新版本,它的一大优点就是支持圆角 1)CSS3圆角的优点 传统的圆角生成方案,必须使用多张图片作为背景图案。CSS3的出现,使得我们再也不必浪费时间去制作这些图片了,而且还有其他多个优点: * 减少维护的工作量。图片文件的生成、更新、编写网页代码,这些工作都不再需要了。 * 提高网页性能。由于不必再发出多余的HTTP请求,网页的载入速度将变快。 * 增加视觉可靠性。某些情况下(网络拥堵、服务器出错、网速过慢等等),背景图片会 下载失败,导致视觉效果不佳。CSS3就不会发生这种情况。 2)border-radius属性 CSS3圆角只需设置一个属性:border-radius(含义是"边框半径")。你为这个属性提供一个值,就能同时设置四个圆角的半径。所有合法的CSS度量值都可以使用:em、ex、pt、px、百分比等等。 CSS3圆角只需设置一个属性:border-radius(含义是"边框半径")。你为这个属性提供一个值,就能同时设置四个圆角的半径。所有合法的CSS度量值都可以使用:em、ex、pt、px、百分比等等。 比如,下面是一个div方框: 现在设置它的圆角半径为15px: border-radius: 15px; 这条语句同时将每个圆角的"水平半径"(horizontal radius)和"垂直半径"(vertical radius)都设置为15px。 border-radius可以同时设置1到4个值。如果设置1个值,表示4个圆角都使用这个值。如果设置两个值,表示左上角和右下角使用第一个值,右上角和左下角使用第二个值。如果设置三个值,表示左上角使用第一个值,右上角和左下角使用第二个值,右下角使用第三个值。如果设置四个值,则依次对应左上角、右上角、右下角、左下角(顺时针顺序)。 border-radius: 15px 5px; border-radius: 15px 5px 25px; border-radius: 15px 5px 25px 0px; (左下角的半径为0,就变成直角了。) border-radius还可以用斜杠设置第二组值。这时,第一组值表示水平半径,第二组值表示垂直半径。第二组值也可以同时设置1到4个值,应用规则与第一组值相同。 border-radius: 15px 5px / 3px; border-radius: 15px 5px 25px / 3px 5px; border-radius: 15px 5px 25px 5px / 3px 5px 10px 15px; 三、单个圆角的设置 除了同时设置四个圆角以外,还可以单独对每个角进行设置。对应四个角,CSS3提供四个单独的属性: * border-top-left-radius * border-top-right-radius * border-bottom-right-radius * border-bottom-left-radius 这四个属性都可以同时设置1到2个值。如果设置1个值,表示水平半径与垂直半径相等。如果设置2个值,第一个值表示水平半径,第二个值表示垂直半径。 border-top-left-radius: 15px; border-top-left-radius: 15px 5px; 四、 浏览器支持 IE 9、Opera 10.5、Safari 5、Chrome 4和Firefox 4,都支持上述的border-radius属性。早期版本的Safari和Chrome,支持-webkit-border-radius属性,早期版本的Firefox支持-moz-border-radius属性。 目前来看,为了保证兼容性,只需同时设置-moz-border-radius和border-radius即可。 -moz-border-radius: 15px; border-radius: 15px; (注意:border-radius必须放在最后声明,否则可能会失效。) 另外,早期版本Firefox的单个圆角的语句,与标准语法略有不同。 * -moz-border-radius-topleft(标准语法:border-top-left-radius) * -moz-border-radius-topright(标准语法:border-top-right-radius) * -moz-border-radius-bottomleft(标准语法:border-bottom-left-radius) * -moz-border-radius-bottomright(标准语法:border-bottom-right-radius) 五、注意事项 虽然各大浏览器都支持border-radius,但是在某些细节上,实现都不一样。当四个角的颜色、宽度、风格(实线框、虚线框等)、单位都相同时,所有浏览器的渲染结果基本一致;一旦四个角的设置不相同,就会出现很大的差异。比如,下面这段代码在不同的浏览器中,渲染结果就相差很大。 border-color: black; border-style: solid dashed; border-width: 1px 2px 3px; border-top-color: red; border-radius: 5%; 另外,并非所有浏览器,都支持将圆角半径设为一个百分比值。 因此,目前最安全的做法,就是将每个圆角边框的风格和宽度,都设为一样的值,并且避免使用百分比值