探究background-position属性中的百分比值的使用
background-position如何影响背景图的展示
这两天在项目中替换首页图片的时候,发现了一个问题,之前的样式设置的是background-position:center,当页面缩小或者放大时背景图显示的区域也会变化,现在改成left top后,页面如何变化大小图片位置都没动。这一想,也不对啊,background-position:center难道不是从元素居中位置才显示背景图吗,为什么还是占满了全部元素区域?这个center到底指的是背景图的center还是元素的center?
background-position属性
background-position为一个集合属性,设置的是背景图的起始位置,分别为background-position-x和background-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%,且无border和padding
例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: 100px 20px 50px 50px; background-position: 0% 0%;
可以看到背景图是在padding区域的左上角,所以background-position的百分值实际参与计算的容器元素宽高 = content + padding
如果背景图尺寸background-size设置为100% 100%的话,那么background-position不论设置为何种百分比都不会发生偏移

反之,如果背景图尺寸大于元素尺寸,设置百分比后发生的就会是负向偏移了。
好了,这下终于把这个属性搞懂了,某些css属性的描述不够准确,容易引起误会,还是要自己实践才能出真知!
到此这篇关于探究background-position属性中的百分比值的使用的文章就介绍到这了,更多相关background-position百分比值内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
相关文章
- CSS Grid 是一种二维布局系统,可以同时控制行和列,相比 Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,这篇文章主要介绍了前端CSS Grid 布局详解,需要的朋2025-04-16
- CSS 中的 padding 和 margin 是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍 padding 和 margin 的概念、区别以及如何在实际项目中使用它们2025-04-07
- will-change 是一个 CSS 属性,用于告诉浏览器某个元素在未来可能会发生哪些变化,本文给大家介绍CSS will-change 属性详解,感兴趣的朋友一起看看吧2025-04-07
- 本文给大家分享在 CSS 中,去除a标签(超链接)的下划线的几种方法,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧2025-04-07
在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交互和动态效果的关键技术之一,随着前端技术的不断发展,CSS的用法也日益丰富和高级,本文将2025-04-07css中的 vertical-align与line-height作用详解
文章详细介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,感兴趣的朋友跟随小编一起看看吧2025-03-26浅析CSS 中z - index属性的作用及在什么情况下会失效
z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fixed或sticky),本文给大家介绍CSS 中z - index属性的作用2025-03-21- 文章详细介绍了CSS中的打印媒体查询@mediaprint包括基本语法、常见使用场景和代码示例,如隐藏非必要元素、调整字体和颜色、处理链接的URL显示、分页控制、调整边距和背景等2025-03-18

CSS模拟 html 的 title 属性(鼠标悬浮显示提示文字效果)
本文介绍了如何使用CSS模拟HTML的title属性,通过鼠标悬浮显示提示文字效果,通过设置`.tipBox`和`.tipBox.tipContent`的样式,实现了提示内容的隐藏和显示,感兴趣的朋友一起2025-03-10
前端 CSS 动态设置样式::class、:style 等技巧(推荐)
本文介绍了Vue.js中动态绑定类名和内联样式的两种方法:对象语法和数组语法,通过对象语法,可以根据条件动态切换类名或样式;通过数组语法,可以同时绑定多个类名或样式,此外2025-02-26





最新评论