CSS中背景图片的background-position中的left top究竟是相对于谁的?

在学习的时候遇到了以下问题:css

  1. CSS中背景图片的background-position中的left top究竟是相对于谁的,content-box?padding-box?border-box?
  2. background属性中的backgound-image和background-color相对的box是一致的吗?
  3. 如何作到背景图片位于容器的右边10px,底边10px?

 首先咱们来看一下盒模型:盒模型从外到内依次为:margin-box,border-box,padding-box,content-box.前端

 

如今咱们来解答一下咱们咱们遇到的第一个问题,及background-position中的left top是相对于哪一个box。答案是相对于padding-box的外边沿。函数

下面的HTML代码和CSS代码分别实现给一个class=“myDiv”的容器设置一副背景图片,背景图片的background-position属性值为left top。HTML代码以下:学习

1 <div class="myDiv"></div>

CSS代码以下:url

1 .myDiv{
2         height:300px;
3         width:400px;
4         border:10px solid black;
5         padding:20px;
6         background: url("road.png") no-repeat top left ;
7      }

效果以下:spa

你们能够看到myDiv的padding设置为20px,图中绿色表明padding,背景图片的左上角恰好和绿色的padding的外边沿对齐,因此第一个问题的答案就是为padding-box;code

刚才咱们看到背景图片是相对于padding-box的外边沿的。如今咱们来看第二个问题,background属性中背景图片和背景颜色相对的box是一致的吗?blog

就刚才的例子,咱们稍微改动一下CSS代码,设置一个粉色的背景,边框设置为虚线,改动后的CSS代码以下:图片

.myDiv{
        height:300px;
        width:400px;
        border:10px dashed black;
        padding:20px;
        background: url("road.png") no-repeat top left pink ;

效果以下:你们能够看到背景颜色是伸展到了border之下的。说明了背景颜色是相对于border-box的外边沿的。因此你们记清楚了,背景图片和背景颜色的相对的box是不一致的。it

 

 如今咱们来看第三个问题:如何作到背景图片位于容器的右边20px,底边20px?

咱们知道若是仅仅background-position:right bottom的话,背景图片是仅仅贴着边框的,以下图所示,这样看起来特别丑,咱们所但愿的是背景图片和边框之间有个padding的距离。

其实CSS3是支持相对任意角来偏移的,只要咱们在偏移量前端指定关键字,咱们将背景位置改成background-position:right 20px bottom 20px;具体的CSS的代码以下:

.myDiv{
        height:300px;
        width:400px;
        border:10px solid black;
        padding:20px;
        background: url("road.png") no-repeat;
        background-position:right 20px bottom 20px;
     }

效果以下:

此外若是咱们还有一种方法,及将background-origin属性设置为content-box,(background-origin属性默认值为为padding-box,即相对于padding框来设置背景)这样就能让背景图片相对于content-box设置了。CSS代码以下:

.myDiv{
        height:300px;
        width:400px;
        border:10px solid black;
        padding:20px;
        background: url("road.png") no-repeat right bottom;
        background-origin: content-box;
     }

效果以下:

 

固然咱们还能够用CSS的calc()函数,以相对于左上角偏移来计算,咱们经过100%-20px,100%-20px经过能获得,只是比较麻烦了,CSS代码以下:

1 .myDiv{
2         height:300px;
3         width:400px;
4         border:10px solid black;
5         padding:20px;
6         background: url("road.png") no-repeat right bottom;
7         background-position:calc(100% - 20px) calc(100% - 20px);
8      }
相关文章
相关标签/搜索