CSS高级技巧:圆角矩形

所谓的CSS高级技巧...其实是一些对基本技巧的创意组合, 任何手段和技巧都是解决问题的方法. 只要学会这种思考问题的方法, 你也能拥有属于自己的CSS秘籍.

CSS2 还没有办法创造出曲线边框, 明显的, 仅仅方框是没办法满足我们设计师的. 所以CSS圆角技术到现在还是那么的火.

1. 固定宽度的纯色圆角矩形


.Com

在众多圆角技术中, 固定宽度的圆角矩形应该是最容易实现的, 只需要2个图片以及一段简单的html代码.

html代码如下: .Com

<div class="wrapper">
    <h1>标题</h1>
    <p>内容</p>
</div>

图片大致如下:

        
                       top.gif                                                      bottom.gif

 CSS代码大致如下: 网页教学网

.wrapper{width:181px;background:#8cc355 url(../images/bottom.gif) no-repeat left bottom;}
.wrapper h1{padding:10px 20px 0 20px;background:url(../images/top.gif) no-repeat left top;}
.wrapper p{padding:0 20px 10px 20px;}

Tips: 网页教学网

wrapper中的宽度(width)是图片的真实宽度, 背景中的背景色是与纯色图片相同的颜色.

h1和p中相应设置了内补丁,为了内容不重叠或碰到外框.

.Com

图片需要有背景色, 即除了圆角矩形纯色部分的颜色以外的区域需要有和当前容器( div class="wrapper" )所在的父级容器相同的背景色. .Com

这种方法适用于宽度固定, 高度自适应的纯色圆角矩形.

.Com

2. 固定宽度的非纯色圆角矩形

这个方法是上一个方法的延伸, 这次我们不在容器上定义背景色, 而是定义重复的背景图片.

html代码如下:

<div class="wrapper">
    <h1>标题</h1>
    <p>内容</p>
</div>

 图片大致如下: 网页教学网

        
                     top.gif                                                     bottom.gif                                                    tile.gif

CSS代码大致如下:

.Com

.wrapper{width:183px;background:url(../images/tile.gif) repeat-y center;}
.wrapper h1{padding:20px 20px 0 20px;background:url(../images/top.gif) no-repeat left top;}
.wrapper p{padding:0 20px 20px 20px;background:url(../images/bottom.gif) no-repeat left bottom;} .Com

Tips: 网页教学网

特性与第一个方法类似;

不能适用于非垂直改变的背景图像.

PS. 固定高度的圆角矩形也可以类似的完成,不赘述了

3. 滑动门技术(Sliding Doors)

前面的两种圆角矩形都是固定宽度的,只能在垂直方向上自适应增长(或水平方向上), 如果需要同时在垂直方向与水平方向上自适应增长尺寸的话, 很显然前两种方法不适用. 这时我们就可以采用所谓的滑动门技术.

原理:

网页教学网

Top-Left.gif 与 Bottom-Left.gif 都是大图像, Top-Right.gif 和 Bottom-Right.gif 都是小图像, 小图像在大图像上根据尺寸进行自动滑动以适应内容.

该方法用到2组4个图片: 1组Top图片构成顶部圆角, 1组Bottom图片构成底部圆角以及主体. 注意容器的最大高度和宽度不能超过图片的最大高度和宽度.

网页教学网

图片的结构位置: 网页教学网

html代码大致如下:

<div class="wrapper">
    <div class="box-outer">
        <div class="box-inner">
            <h1>标题</h1>
            <p>内容</p>
        </div>
    </div>
</div>

.Com

CSS代码大致如下:

.wrapper{width:20em;background:#ccc url(../images/bottom-left.gif) no-repeat left bottom;}
.box-outer{background:url(../images/bottom-right.gif) no-repeat right bottom;}
.box-inner{background:url(../images/top-left.gif) no-repeat left top;}
.wrapper h1{padding:2%;background:url(../images/top-right.gif) no-repeat right top;}
.wrapper p{padding:2%;}
网页教学网

Tips:

该方法很好的解决了容器扩展的问题, 但是要注意容器的最大尺寸不要超过背景图片所能构成的最大尺寸;

该方法需要2组额外的没有任何语义的标签, 在结构上并不理想, 我们可以用JavaScript和DOM动态添加额外元素来避免这个问题, JavaScript不作讨论.

网页教学网

滑动门适用范围很广, 以至于随处可见. .Com

4. 山顶角(MountainTop)

Web大师Dan Cederholm的发明, 和他在Web Standard Solutions中的变色龙小图标有异曲同工之妙. 网页教学网

如果用 3.滑动门 的技术创建多种颜色的圆角矩形, 那是不是要建立多组不同颜色的图片呢? 那是不是会很麻烦呀? 幸运的是Dan为我们带来了山顶角. 他建立的不是多种颜色的图片组, 而是一组圆角的蒙板. 用蒙板盖住背景色, 生成圆角矩形, 这种逆向思维令人敬佩.


                                                   圆角蒙板

基本的HTML代码和CSS代码与上例相同, 也需要4个不同的圆角蒙板. 代码不做重复.

网页教学网

Tips:

可以使用.png来创建圆滑的透明蒙板, 但介于IE6和以下版本不支持png-24的透明效果, 需要用到Hacks, 所以不太推荐. 所以对于gif图片的蒙板, 对于小弧度的圆角矩形效果较好, 大弧度的圆角矩形可能会出现锯齿. 同样的需要添加额外的非语义标签, 语义化狂热者们可以用JavaScript来完成这个工作.

5. CSS Sprites 圆角

CSS Sprites并不是专门制作圆角矩形的, 但是它提供了一种制作圆角矩形的方案.


                                      结构构成图 .Com

                                           
                             实际用到的圆角小图

网页教学网

只单单用background的position来指定圆角图片背景定位, 但是会多出很多额外标签, 这里不做推荐. .Com

下一篇CSS教程文章:CSS高级技巧:CSS Sprites. .Com

时间: 2024-09-12 04:03:44

CSS高级技巧:圆角矩形的相关文章

CSS高级技巧:CSS Sprites

上一篇CSS教程文章:CSS高级技巧:圆角矩形 网页教学网 CSS Sprites, 利用CSS background-position 进行背景绝对定位, 减少HTTP请求, 加速网页显示, 解决图片载入闪动问题的技巧. 网页教学网 CSS Sprites最适合用来做的, 恩, 比如: 清单导航的CSS鼠标翻转效果 大量小图标集中的应用 (FckEditor) ...很多很多,多的想不出来了. 实现原理简单地说就是控制容器的大小, 然后利用background-repeat, backgrou

CSS高级技巧之圆角矩形

所谓的CSS高级技巧...其实是一些对基本技巧的创意组合, 任何手段和技巧都是解决问题的方法. 只要学会这种思考问题的方法, 你也能拥有属于自己的CSS秘籍. CSS2 还没有办法创造出曲线边框, 明显的, 仅仅方框是没办法满足我们设计师的. 所以CSS圆角技术到现在还是那么的火. 1. 固定宽度的纯色圆角矩形 在众多圆角技术中, 固定宽度的圆角矩形应该是最容易实现的, 只需要2个图片以及一段简单的html代码. html代码如下: <div class="wrapper">

CSS圆角矩形的技巧

  所谓的CSS高级技巧...其实是一些对基本技巧的创意组合, 任何手段和技巧都是解决问题的方法. 只要学会这种思考问题的方法, 你也能拥有属于自己的CSS秘籍. CSS2 还没有办法创造出曲线边框, 明显的, 仅仅方框是没办法满足我们设计师的. 所以CSS圆角技术到现在还是那么的火. 1. 固定宽度的纯色圆角矩形 在众多圆角技术中, 固定宽度的圆角矩形应该是最容易实现的, 只需要2个图片以及一段简单的html代码. html代码如下: Webjx.Com 标题 内容 图片大致如下: top.g

css圆角矩形

csscss圆角矩形 测试 无图片 无图片实现圆角框

CSS高级技巧:滑动门技术

上一篇CSS教程 文章:CSS高级技巧:图片替换 网页教学网 滑动门(Sliding Doors) 还是决定把滑动门单独提作一种单独的技术. 它是CSS引入的一项用来创造漂亮且实用的界面的新技术, 它使用简单, 我们只需要使用两张单独的背景图片, 就可以实现. 网页教学网 滑动门一般用做网站Tab导航, 根据Tab中内容的长短自动缩放Tab的效果. 前面所述的圆角矩形只是它的一种实现方式而已. 真正的滑动门只需要2组标签就可以完成: 网页教学网 HTML代码如下: .Com <ul>    &

如何实用css制作圆角

css制作圆角教程,有html代码和css全部代码. 不用图片,只用css制作圆角的另一方法. html代码: <div class="curvedBox"> <span> <span class="r1" ></span> <span class="r2" ></span> <span class="r3" ></span> &l

像素模型实现圆角矩形

圆角  就是利用px单位的块级元素拼合而形成一个视觉上的圆角矩形,因为1px在人的视觉感受中不是很明显,就感觉它是圆滑的圆角矩形了. 查看模型图示: 代码:css:.con{margin: 2% 5%; background: #000; color: #fbca04} b.rtop,b.rbottom{display: block; background: #333} b.rtop b,b.rbottom b{display: block; height: 1px; overflow: hid

div+css实现圆角边框:

我在这里介绍的是实现圆角矩形边框的方法.用代码说明问题  代码如下 复制代码 :<html><head><style>#a{border-left:1px #333 solid;border-right:1px #333 solid;width:300px;height:500px;}.b{height:1px;overflow:hidden;border-left:1px #333 solid;border-right:1px #333 solid;}</sty

android-如何给GridView创建一个圆角矩形边界?

问题描述 如何给GridView创建一个圆角矩形边界? 我想给GridView创建一个圆角矩形边界,就像以下的图像显示一样:如何实现这个功能呢? 解决方案 创建一个 drawable shape ,在 view 中设置为背景 <?xml version=""1.0"" encoding=""utf-8""?><shape xmlns:android=""http://schemas.and