background-position属性中的百分比值探索

目录
文章目录隐藏
  1. background-position 如何影响背景图的展示?
  2. background-position 属性
  3. 设置为百分比值的实际情况

background-position 如何影响背景图的展示?

这两天在项目中替换首页图片的时候,发现了一个问题,之前的样式设置的是background-position:center,当页面缩小或者放大时背景图显示的区域也会变化,现在改成left top后,页面如何变化大小图片位置都没动。这一想,也不对啊,background-position:center难道不是从元素居中位置才显示背景图吗,为什么还是占满了全部元素区域?这个center到底指的是背景图的center还是元素的center

background-position 属性

background-position为一个集合属性,设置的是背景图的起始位置,分别为background-position-xbackground-position-y,可用的值有left,right,top,bottom,以及固定像素值和百分比值。

  • background-position-x: left (等价于 0%)
  • background-position-x: right (等价于 100%)
  • background-position-y: top (等价于 0%)
  • background-position-x: bottom (等价于 100%)

抛开固定像素值定位,那么这次主要探究百分比值对背景图位置的影响,百分比值正常来看应该是相对于元素的宽高的百分比,然而实际表现却不是如此。

设置为百分比值的实际情况

注:此次用作背景元素容器的元素宽高设置为100%100%,且无borderpadding

例 1:

设置为百分比值的实际情况

background-size: 100px 100px;
background-position: 100% 100%;

可以看到,当background-position设置为百分之百的时候,背景图在窗口的右下角显示而不是溢出元素区域之外

接下来改变位置

例 2:

改变位置

background-size: 100px 100px;
background-position: 50% 50%;

可以看到,现在背景图现在处于元素正中央的位置,为了证实是正中央的位置,我用了一个具有居中样式的子元素做对比,可以看到正好被子元素框柱。

通过以上两例可以看出:

background-position设置为100% 100%的时候,图片在最右下角位置,那么此时background-position-x的像素值等于「容器元素的宽度值减去背景图的宽度」background-position-y的像素值等于「容器元素的高度值减去背景图的高度」

background-position设置为50% 50%的时候,图片在元素内部居中位置,那么此时background-position-x的像素值等于「容器元素的宽度值乘以 50%再减去背景图宽度的 50%」background-position-y的像素值等于「容器元素的高度值乘以 50%再减去背景图高度的 50%」

如果用w代表容器元素宽度,h代表容器元素高度,bw代表背景图宽度,bh代表背景图高度,通过以上两例可以得出这么一个公式:

background-position-x: percent = (w - bw) * percent
background-position-y: percent = (h - bh) * percent

在元素有 padding 的情况下:

在元素有 padding 的情况下:

padding: 100px 20px 50px 50px;
background-position: 0% 0%;

可以看到背景图是在padding区域的左上角,所以background-position的百分值实际参与计算的容器元素宽高 = content + padding

如果背景图尺寸background-size设置为100% 100%的话,那么background-position不论设置为何种百分比都不会发生偏移

背景图尺寸 background-size 设置为 100% 100%

反之,如果背景图尺寸大于元素尺寸,设置百分比后发生的就会是负向偏移了。

好了,这下终于把这个属性搞懂了,某些 css 属性的描述不够准确,容易引起误会,还是要自己实践才能出真知!

「点点赞赏,手留余香」

0

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » background-position属性中的百分比值探索

发表回复