如何使用CSS3中background-image实现多背景图片

发布时间:2020-06-11 12:08:56 作者:Leah
来源:亿速云 阅读:431

如何使用CSS3中background-image实现多背景图片?针对这个问题,今天小编总结了这篇文章,希望能帮助更多想解决这个问题的朋友找到更加简单易行的办法。

问题:

1、实现以下效果,使用纯DIV+CSS,必须使用background-image

如何使用CSS3中background-image实现多背景图片

附加说明:

1、整体宽度是1000px,高300px,要求页面居中显示

2、背景图片宽,高均为300px

3、每张图片都是当做背景图片来呈现的

现在来具体操作

1、准备素材:根目录创建images文件夹,把相关素材图片都存放与此,素材有

如何使用CSS3中background-image实现多背景图片

如何使用CSS3中background-image实现多背景图片

如何使用CSS3中background-image实现多背景图片

2、创建好index.html,写好架构,架构如何分析呢

思路分析:

1、目标由3个div组成,每个div的背景图片都是一样的,都是3张照片,只不过仔细观察,就是第二张背景图片的位置显示不同

2、每个div都带有一个标题

根据分析,我们得出以下代码

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>多重背景</title>
    <link rel="stylesheet" href="css/index.css" />
</head>
<body>
    <div class="container">
        <h5>效果1</h5>
        <div class="demo bg1"></div>
        <h5>效果2</h5>
        <div class="demo bg2"></div>
        <h5>效果3</h5>
        <div class="demo bg3"></div>
    </div>
</body>
</html>

3、写样式 ,创建css文件夹,里面新建index.css,里面的样式怎么写了,以下是分析思路

思路分析:

1、.container *

思路分析

1、为了设置容器里的所有元素的公共样式,我们可以将这些公共代码写入.container * 样式内

所以index.css中添加代码如下:

.container *{
    padding:0;
    margin:0;
}

2、h5标题

思路分析:

1、要求文本居中,所以转成代码即 text-align: center;、

所以index.css中添加代码如下:

h5{
    text-align: center;
}

3、.demo

思路分析:

1、根据要求得知宽1000,高300,所以转成代码即width:1000px;height:300px;背景图片不是一张是3张,且不重复所以

background-image: url(images/gtl1.jpg),
                               url(images/gtl2.jpg),
                               url(images/gtl3.jpg);

background-repeat: no-repeat, no-repeat, no-repeat;

带边框所以border: 1px solid #999;要居中且有上边距所以margin: 0 auto 20px auto;

所以index.css中添加代码如下:

.demo {
    width: 1000px;
    height: 300px;
    border: 1px solid #999;
    background-image: url(images/gtl1.jpg),
        url(images/gtl2.jpg),
        url(images/gtl3.jpg);

    background-repeat: no-repeat, no-repeat, no-repeat;
    margin: 0 auto 20px auto;
}

4、3种不同的背景位置设置

思路分析:

1、第一种方式是第一张背景图片靠最左边显示,第二张居中,此刻它的left值=(1000-300)/2=350,第三张在最右边

2、第二种方式是第一张背景图片靠最左边显示,第二张紧挨着第一张,此刻它的left值=第一张背景图片的宽度300,第三张在最右边

3、第三种方式是第一张背景图片靠最左边显示,第二张紧挨着第三张,此刻它的left值=1000-第二张+第三张的总体宽度=1000-600=400,第三张在最右边

注意:如果都不设置background-positon默认都是靠左显示,那么会存在重叠的情况

所以index.css中添加代码如下:

.bg1 {
    background-position: left top, 350px 0, 700px 0;
}

.bg2 {
    background-position: left top, 300px 0, 700px 0;
}

.bg3 {
    background-position: left top, 400px 0, 700px 0;
}

到此为止,index.css的全部内容如下:

.container *{
    padding:0;
    margin:0;
}
h5{
    text-align: center;
}
.demo {
    width: 1000px;
    height: 300px;
    border: 1px solid #999;
    background-image: url(../images/gtl1.jpg),
        url(../images/gtl2.jpg),
        url(../images/gtl3.jpg);

    background-repeat: no-repeat, no-repeat, no-repeat;
    margin: 0 auto 20px auto;
}

.bg1 {
    background-position: left top, 350px 0, 700px 0;
}

.bg2 {
    background-position: left top, 300px 0, 700px 0;
}

.bg3 {
    background-position: left top, 400px 0, 700px 0;
}

然后将index.css引入index.html中

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>多重背景</title>
    <link rel="stylesheet" href="css/index.css" />
</head>

<body>
    <div class="container">
        <h5>效果1</h5>
        <div class="demo bg1"></div>
        <h5>效果2</h5>
        <div class="demo bg2"></div>
        <h5>效果3</h5>
        <div class="demo bg3"></div>
    </div>

</body>

</html>

运行效果如下

如何使用CSS3中background-image实现多背景图片

到此为止,我们就实现了全部的需求

总结:

1、background-image可以设置多背景图片,语法格式如下:

background-image: url(图片地址1),

url(图片地址2),

url(图片地址3).......还可以N个;

2、如果设置了多背景图片,那么在设置 background-repeat和 background-position的时候要注意顺序和图片设置的顺序一样,如果设置成一个,那么说明所有的背景图片都是一样的设置

看完这篇文章,你们学会使用CSS3中background-image实现多背景图片的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读。

推荐阅读:
  1. 如何使用background-image属性
  2. CSS3中如何使用background-size定义背景图片大小

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

css3 background-image gr

上一篇:Android 学习笔记--android——Notification

下一篇:javascript正则表达式的字符匹配

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》