对于元素的边框我们除了可以使用之前介绍的一些默认样式外,还可以通过 CSS3 中的 border-image 属性使用图像来作为元素的边框,以创建出丰富多彩边框效果。

border-image 属性可以通过一些简单的规则,将一副图像划分为 9 个单独的部分,浏览器会自动使用相应的部分来替换边框的默认样式。border-image 属性是五个 border-image-* 属性的简写,其语法格式如下:

border-image:border-image-source || border-image-slice [ / border-image-width | / border-image-width ? / border-image-outset ]? || border-image-repeat
repeat属性的简写
border-image-source定义边框图像的路径
border-image-slice定义边框图像从什么位置开始分割
border-image-width定义边框图像的厚度(宽度)
border-image-outset定义边框图像的外延尺寸(边框图像区域超出边框的量)
border-image-repeat定义边框图像的平铺方式

接下来我们通过如下所示的图片来演示一下 border-image-source、border-image-slice、border-image-width、border-image-outset 和 border-image-repeat 几个属性的使用。

图片


1. border-image-source

border-image-source 属性用来定义边框要使用的图像,通过该属性可以指定一个图像来替换边框的默认样式,当 border-image-source 属性的值为 none 或者指定的图像不可用时,则会显示边框默认的样式。

另外,border-image-source 属性除了可以使用图像来替换边框的默认样式外,您还可以使用渐变来定义边框样式,属性的语法格式如下:

border-image-source:none | <image>

其中,none 为 border-image-source 属性的默认值,表示不使用图像来替换边框的默认样式;<image> 为使用 url() 函数指定的图像路径或者使用 linear-gradient() 函数定义的渐变色,用来替换默认的边框样式。

【示例】通过 border-image-source 属性使用图像来替换默认的边框样式:

<!DOCTYPE html>
<html>
<head>
    <style>
        div {
            width: 200px;
            border: 27px solid;
            padding: 10px;
            border-image-source: url(./img.png);
        }
    </style>
</head>
<body>
    <div>使用图片替换默认边框</div>
</body>
</html>

运行结果:

border-image-source

通过运行结果可以看出,仅仅借助 border-image-source 属性并不能达到我们想要的效果,我们再来看一下其它几个函数。


2. border-image-slice

border-image-slice 属性用来分割通过 border-image-source 属性加载的图像,属性的语法格式如下:

border-image-slice:[ <number> | <percentage> ]{1,4} && fill?

border-image-slice 属性可以接收三种类型的值:

1. <number>:数值,用具体数值指定图像分割的位置,数值代表图像的像素位置或向量坐标,不允许负值;

2. <percentage>:百分比,相对于图像尺寸的百分比,图像的宽度影响水平方向,高度影响垂直方向;

3. fill:保留边框图像的中间部分。

border-image-slice 属性可以指定上、下、左、右四个方位来分割图像,并将图像分成 4 个角、4条边和中间区域等 9 个部份,中间区域始终是透明的(即没图像填充),除非加上关键字 fill,如下图所示:

border-image-slice


除 fill 关键字外,border-image-slice 属性可以接受 1~4 个参数值:

1. 如果提供全部四个参数值,那么将按上、右、下、左的顺序对图像进行分割;

2. 如果提供三个参数,那么第一个参数用于上方,第二个参数用于左、右两侧,第三个参数用于下方;

3. 如果提供两个参数,那么第一个参数用于上方和下方,第二个参数用于左、右两个;

4. 如果只提供一个参数,那么上、右、下、左都将使用该值进行分割。

【示例】使用 border-image-slice 属性用来分割通过 border-image-source 属性加载的图像:

<!DOCTYPE html>
<html>
<head>
    <style>
        div {
            width: 200px;
            border: 27px solid;
            padding: 10px;
            border-image-source: url(./img.png);
            border-image-slice: 27;
        }
    </style>
</head>
<body>
    <div>使用图片替换默认边框</div>
</body>
</html>

运行结果:

border-image-source

3. border-image-width

border-image-width 属性用来设置通过 border-image-source 属性加载的图像厚度(宽度),属性的语法格式如下:

border-image-width:[ <length> | <percentage> | <number> | auto ]{1,4}

语法说明如下:

1. <length>:使用数值加单位的形式指定图像边框的宽度,不允许为负值;

2. <percentage>:用百分比的形式指定图像边框的宽度,参照图像边框区域的宽和高进行换算,不允许负值;

3. <number>:使用浮点数指定图像边框的宽度,该值对应 border-width 的倍数,例如值为 2,则参数的实际值为 2 * border-width,不允许负值;

4. auto:由浏览器自动设定,当 border-image-width 设置为 auto 时,它的实际值与 border-image-slice 相同的值。

提示:border-image-width 属性的默认值为 1,也就是说当我们省略 border-image-width 属性的值时,该属性的值会被设置为 1 * border-width,相当于会直接使用 border-width 的值。

border-image-width 属性同样可以接受 1~4 个参数值:

1. 如果提供全部四个参数值,那么将按照上、右、下、左的顺序设置图像边框四个方向上的宽度;

2. 如果提供三个参数,那么第一个参数用于上边框,第二个参数用于左、右两个边框,第三个参数用于下边框;

3. 如果提供两个参数,那么第一个参数用于上、下两个边框,第二个参数用于左、右两个边框;

4. 如果只提供一个参数,那么上、右、下、左都将使用该值设置图像边框的宽度。

【示例】使用 border-image-width 属性设置图像边框的宽度:

<!DOCTYPE html>
<html>
<head>
    <style>
        div {
            width: 200px;
            border: 27px solid;
            padding: 10px;
            border-image-source: url(./img.png);
            border-image-slice: 27;
            border-image-width: 10px 1 0.5 15px;
        }
    </style>
</head>
<body>
    <div>使用图片替换默认边框</div>
</body>
</html>

运行结果:

border-image-width


4. border-image-outset

border-image-outset 属性用来定义图像边框相对于边框边界向外偏移的距离(使图像边框延伸到盒子模型以外),该属性的语法格式如下:

border-image-outset:[ <length> | <number> ]{1,4}

 语法说明如下:

1. <length>:用具体的数值加单位的形式指定图像边框向外偏移的距离,不允许为负值;

2. <number>:用浮点数指定图像边框向外偏移的距离,该值表示 border-width 的倍数,例如值为 2,则表示偏移量为 2 * border-width,不允许为负值。

1. border-image-outset 属性同样可以接受 1~4 个参数值:

2. 如果提供全部四个参数值,那么将按上、右、下、左的顺序作用于四边;

3. 如果提供三个参数值,那么第一个参数将用于上边框,第二个参数将用于左、右两个边框,第三个参数将用于下边框;

4. 如果提供两个参数,那么第一个参数将用于上、下两个边框,第二个参数将用于左、右两个边框;

5. 如果只提供一个参数,那么该参数将同时作用于四边。

【示例】使用 border-image-outset 属性设置图像边框相对于边框边界向外的偏移量:

 border-image-outset

5. border-image-repeat

border-image-repeat 属性用来设置如何填充使用 border-image-slice 属性分割的图像边框,例如平铺、拉伸等等,该属性的语法格式如下:

border-image-repeat:[ stretch | repeat | round | space ]{1,2}

语法说明如下:

1. stretch:将被分割的图像使用拉伸的方式来填充满边框区域;

2. repeat:将被分割的图像使用重复平铺的方式来填充满边框区域,当图像碰到边界时,超出的部分会被截断;

3. round:与 repeat 关键字类似,不同之处在于,当背景图像不能以整数次平铺时,会根据情况缩放图像;

4. space:与 repeat 关键字类似,不同之处在于,当背景图像不能以整数次平铺时,会用空白间隙填充在图像周围。

border-image-repeat 属性能够接受 1~2 个参数值:

1. 如果提供两个参数,那么第一个参数将用于水平方向,第二个将用于垂直方向;

2. 如果只提供一个参数,那么将在水平和垂直方向都应用该值。

【示例】使用 border-image-repeat 属性设置图像边框的填充方式:

<!DOCTYPE html>
<html>
<head>
    <style>
        div {
            width: 200px;
            border: 27px solid;
            padding: 10px;
            border-image-source: url(./img.png);
            border-image-slice: 27;
            border-image-repeat: round repeat;
        }
    </style>
</head>
<body>
    <div>使用图片替换默认边框</div>
</body>
</html>

运行结果:

border-image-repeat


6. border-image

了解完 border-image-source、border-image-slice、border-image-width、border-image-outset 和 border-image-repeat 这几个属性,我们回头再来看看 border-image 属性。border-image 属性是五个 border-image-* 属性的简写,通过 border-image 属性可以同时设置五个 border-image-* 属性。

【示例】使用 border-image 属性设置图片边框:

border-image


点赞(0)

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

Dotcpp在线编译      (登录可减少运行等待时间)