CSS高级技巧:圆角矩形

2016-02-19 23:31 7 1 收藏

今天天气好晴朗处处好风光,好天气好开始,图老师又来和大家分享啦。下面给大家推荐CSS高级技巧:圆角矩形,希望大家看完后也有个好心情,快快行动吧!

【 tulaoshi.com - Web开发 】

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

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

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

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

html代码如下:

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中相应设置了内补丁,为了内容不重叠或碰到外框.

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

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

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

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

html代码如下:

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

 图片大致如下:

        
                     top.gif                                                     bottom.gif                                                    tile.gif

CSS代码大致如下:

.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;}

Tips:

特性与第一个方法类似;

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

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

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:

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

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

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

4. 山顶角(MountainTop)

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

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


                                                   圆角蒙板

5. CSS Sprites 圆角

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


                                      结构构成图

                                           
                             实际用到的圆角小图

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

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

来源:https://www.tulaoshi.com/n/20160219/1630095.html

延伸阅读
标签: Web开发
要一个宽度不固定的框,事情变得有些复杂了。宽度不固定,就意味着这个框在水平和垂直方向都有足够灵活的变化。 为什么说这更难一些呢?因为它需要对四张图片的合适安置——每个圆角用一张。每个圆角都要独立出来,以便框能够在各个方向伸展。于是,四张图片就意味着需要四个HTML对象来作为背景图片的载体。 有一些实现办法包括在样式...
标签: Web开发
上一篇 CSS教程 文章:CSS高级技巧:滑动门 文字环绕图片(SandBags) 在印刷业中, 常用的文字图片混搭的排版法被延伸到了Web视觉设计中, 如何来完成呢? 这里说的并不是简单的文字包围图片, 不过原理很类似, 同样是通过float属性来完成效果的. 先看一看效果图: 这应该不是简单的图片float能完成的了吧? 不过实现的原理还是不是很推荐,...
标签: CorelDRAW
  众所周知当今流行的矢量图软件无非为以下三种,Corel公司的CorelDRAW、Adobe公司的Illustrator、及Macromedia公司的Freehand,其中CorelDRAW以其更新速度快(据说CorelDRAW 11.0简体中文版即将出版),整体功能强大,简而易学的操作赢得不少专业人士及非专业人士的青睐。 然而好东西并非完美无缺,亦难免有所瑕疵。今天要讲是...
标签: Web开发
我们接下来会创建一个xHTML页面,内含两个分别被ID为fixedBox与FlowBox的DIV所包含的两个内容区域,分别为固定宽度与不固定宽度的两个DIV,现在我们来为这两个DIV加上圆角。 我们所使用的理论是:在为元素添加背景时,背景图片总是显示在背景色之上;要创建单色的圆角矩形框,我们可以先创建一个正常的矩形框,然后,使用与背景色一致...
标签: Web开发
不用图片,只用css制作圆角的另一方法。来自 html div class="curvedBox"spanspan class="r1" /spanspan class="r2" /spanspan class="r3" /spanspan class="r4" /span /spandiv class="content"Flex is a cross-platform development framework for creating rich Internet...

经验教程

766

收藏

84
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部