第 17 章 CSS 边框与背景[下]

    1.设置背景

    主讲教师:李炎恢

    本章主要探讨 HTML5 中 CSS 边框和背景,通过边框和背景的样式设置,给元素增加更丰富的外观。

    一.设置背景

    盒模型的尺寸可以通过两种方式实现可见性,一种就是之前的边框,还有一种就是背景。 CSS 背景设置的样式表如下:

    1.background-color

    说明 CSS 版本
    颜色 设置背景颜色为指定色 1
    transparent 设置背景颜色为透明色 1

    解释:设置元素的背景颜色。属性值是颜色值。

    1. }

    解释:默认值为 transparent,为透明的意思。这样<div>内部的元素就会继承<div>的背景色。一般来说这个属性使用频率很低,原因是不需要改变色彩时就默认,需要改变色彩时又是颜色值。

    1. body { background-color: silver;
    2. }

    解释:在<body>元素下可以设置整个页面的背景色。

    2.background-image

    说明 CSS 版本
    none 取消背景图片的设置 1
    url 通过 URL 设置背景图片 1
    1. body { background-image: url(loading.gif);
    2. }

    解释:url 里面是图片的路径,设置整个页面以这个图片为背景,如果图片不足以覆盖,则复制扩展。

    1. div { background-image: none;

    解释:如果多个 div 批量设置了背景,而其中某一个不需要背景,可以单独设置 none 值取消背景。

    3.background-repeat

    解释:让背景图片只显示一个,不平铺。CSS3 还提供了两个值,由于支持度不佳,这里忽略。

    4.background-position

    说明 CSS 版本
    top 将背景图片定位到元素顶部 1
    left 将背景图片定位到元素左部 1
    right 将背景图片定位到元素右部 1
    bottom 将背景图片定位到元素底部 1
    center 将背景图片定位到元素中部 1
    长度值 使用长度值偏移图片的位置 1
    百分数 使用百分数偏移图片的位置 1
    1. }

    解释:将背景图片置于页面上方,如果想置于左上方则值为:top left。

    1. body { background-image: url(loading.gif); background-repeat: no-repeat; background-position: 20px 20px;
    2. }

    解释:使用长度值或百分数,第一值表示左边,第二个值表示上边。

    5.background-size

    说明 CSS 版本
    auto 默认值,图像以本尺寸显示 3
    cover 等比例缩放图像,使图像至少覆盖容器,但有可能超出容器 3
    contain 等比例缩放图像,使其宽度、高度中较大者与容器横向或纵向重合 3
    长度值 CSS 长度值,比如 px、em 3
    百分数 比如:100% 3
    1. body { background-image: url(loading.gif); background-size: cover;
    2. }

    解释:使用 cover 相当于 100%,全屏铺面一张大图,这个值非常实用。在等比例放大缩小的过程中,可能会有背景超出,当然,这点无伤大雅。

    1. div { background-image: url(loading.gif); background-size: contain;

    解释:使用 contain 表示,尽可能让图片完整的显示在元素内。

    解释:长度值的用法,分别表示长和高。

    6.background-attachment

    1. }

    解释:fixed 属性会导致背景产生水印效果,拖动滚动条而背景不动。

    7.background-origin

    说明 CSS 版本
    border-box 在元素盒子内部绘制背景 3
    padding-box 在内边距盒子内部绘制背景 3
    content-box 在内容盒子内部绘制背景 3
    1. div { width: 400px; height: 300px; border: 10px dashed red; padding: 50px; background-image: url(img.png); background-repeat: no-repeat; background-origin: content-box;
    2. }

    8.background-clip

    说明 CSS 版本
    border-box 在元素盒子内部裁剪背景 3
    padding-box 在内边距盒子内部裁剪背景 3
    content-box 在内容黑子内部裁剪背景 3
    1. div { width: 400px; height: 300px; border: 10px dashed red; padding: 50px; background-image: url(img.png); background-repeat: no-repeat; background-origin: border-box; background-clip: padding-box;
    2. }

    解释:在内边距盒子内部裁剪背景。

    9.background

    1. div { width: 400px; height: 300px; border: 10px dashed red; padding: 50px; background: silver url(img.png) no-repeat scroll left top/100% border-box content-box;

    解释:完整的简写顺序如下:

    [background-color]

    [background-image]

    [background-repeat]

    [background-attachment]

    [background-position]/[background-size]

    [background-origin]

    [background-clip]