CSS实现背景图片屏幕自适应

在做登陆页面等的首页的时候,经常会遇到需要放一张背景大图的情况,并且需要图片按比例缩放,来适应不同屏幕的大小。

html 代码如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 
 4 <head>
 5     <meta charset="UTF-8">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <meta http-equiv="X-UA-Compatible" content="ie=edge">
 8     <link rel="stylesheet" href="../css/login.css"><!-- 我的 css 代码路径 -->
 9 
10     <title>。。。</title>
11 </head>
12 
13 <body>
14     <div class="bgimg">
15 </body>
16 
17 </html>

 

  

css 代码如下:

 1 .bgimg{
 2     position:fixed;
 3     top: 0;
 4     left: 0;
 5     width:100%;
 6     height:100%;
 7     min-width: 1000px;
 8     z-index:-10;
 9     zoom: 1;
10     background-color: #fff;
11     background: url(../img/bg_login.jpg) no-repeat;
12     background-size: cover;
13     -webkit-background-size: cover;
14     -o-background-size: cover;
15     background-position: center 0;
16 }

 

分析一下 css 代码中的作用:

1
2
3
position:fixed;
top: 0;
left: 0;

  这三句是让整个 div 固定在屏幕的最上方和最左方

1
2
3
width:100%;
height:100%;
min-width: 1000px;

  上面前两句是让整个 div 跟屏幕大小一样,从而达到全屏效果。而 min-width 是为了实现让屏幕宽度在 1000px 以内时,div 的大小保持不变,也就是图片不缩放。

1
z-index:-10;  
这个的目的是让整个 div 在 HTML 页面中各个层级的下方,正常情况下,默认创建的层级 z-index 的值是 0,所以如果我们这里写成 -1 也可以实现,不过这里写 -10 是确保整个 div 在最下面,因为如果页面中层级太多了,有的时候用 -1 不一定在最下面,但如果写成 -100 这样大数字的也没有什么意义。用 -10 以此能达到看上去像背景图片,其实是一个最普通的 div,只是层级关系变了,才让人看上去看是背景图片。
1
zoom: 1;

  zoom 是 CSS hack 中专对 IE6 起作用的部分。IE6 浏览器会执行 zoom:1 表示对象的缩放比例。兼容 IE6、IE7、IE8 浏览器,经常会遇到一些问题,可以使用 zoom:1 来解决,zoom 有如下作用:1. 触发 IE 浏览器的 haslayout; 2. 解决 ie 下的浮动,margin 重叠等一些问题。 

1
background-repeat: no-repeat;

  图片平铺,不重复

1
2
3
background-size: cover;
-webkit-background-size: cover;
-o-background-size: cover;

  上面三句是一个意思,就是让图片随屏幕大小同步缩放,但是有部分可能会被裁切,不过不至于会露白,下面两句是为 chrome 和 opera 浏览器作兼容。

1
background-position: center 0;

  上面这句的意思就是图片的位置,居中,靠左对齐

 

效果如下:

大于 1000px 时:(截图太大了,我把图片缩小了点)

 

小于 1000px 时:

 

原图:(这个也太大了缩小了点)

 


作者:汤利利
链接:https://www.jianshu.com/p/5480cd1a5d89
来源:简书